msxml3: Added IDispatch support for IServerXMLHTTPRequest.
This commit is contained in:
parent
1a94d8f3c1
commit
ec2114e66e
@ -150,7 +150,8 @@ static tid_id_t tid_ids[] = {
|
|||||||
{ &IID_IMXAttributes, LibXml2 },
|
{ &IID_IMXAttributes, LibXml2 },
|
||||||
{ &IID_IMXReaderControl, LibXml2 },
|
{ &IID_IMXReaderControl, LibXml2 },
|
||||||
{ &IID_IMXWriter, LibXml2 },
|
{ &IID_IMXWriter, LibXml2 },
|
||||||
{ &IID_IVBMXNamespaceManager, LibXml2 }
|
{ &IID_IVBMXNamespaceManager, LibXml2 },
|
||||||
|
{ &IID_IServerXMLHTTPRequest, LibXml2 }
|
||||||
};
|
};
|
||||||
|
|
||||||
const IID *get_riid_from_tid(tid_t tid)
|
const IID *get_riid_from_tid(tid_t tid)
|
||||||
|
@ -1590,9 +1590,10 @@ static HRESULT WINAPI ServerXMLHTTPRequest_GetTypeInfoCount(IServerXMLHTTPReques
|
|||||||
{
|
{
|
||||||
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
||||||
|
|
||||||
FIXME("(%p)->(%p): stub\n", This, pctinfo);
|
TRACE("(%p)->(%p)\n", This, pctinfo);
|
||||||
|
*pctinfo = 1;
|
||||||
|
|
||||||
return E_NOTIMPL;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI ServerXMLHTTPRequest_GetTypeInfo(IServerXMLHTTPRequest *iface, UINT iTInfo,
|
static HRESULT WINAPI ServerXMLHTTPRequest_GetTypeInfo(IServerXMLHTTPRequest *iface, UINT iTInfo,
|
||||||
@ -1600,20 +1601,32 @@ static HRESULT WINAPI ServerXMLHTTPRequest_GetTypeInfo(IServerXMLHTTPRequest *if
|
|||||||
{
|
{
|
||||||
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
||||||
|
|
||||||
FIXME("(%p)->(%u %u %p): stub\n", This, iTInfo, lcid, ppTInfo);
|
TRACE("(%p)->(%u %u %p)\n", This, iTInfo, lcid, ppTInfo);
|
||||||
|
|
||||||
return E_NOTIMPL;
|
return get_typeinfo(IServerXMLHTTPRequest_tid, ppTInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI ServerXMLHTTPRequest_GetIDsOfNames(IServerXMLHTTPRequest *iface, REFIID riid,
|
static HRESULT WINAPI ServerXMLHTTPRequest_GetIDsOfNames(IServerXMLHTTPRequest *iface, REFIID riid,
|
||||||
LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
|
LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
|
||||||
{
|
{
|
||||||
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
||||||
|
ITypeInfo *typeinfo;
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
FIXME("(%p)->(%s %p %u %u %p): stub\n", This, debugstr_guid(riid), rgszNames, cNames,
|
TRACE("(%p)->(%s %p %u %u %p)\n", This, debugstr_guid(riid), rgszNames, cNames,
|
||||||
lcid, rgDispId);
|
lcid, rgDispId);
|
||||||
|
|
||||||
return E_NOTIMPL;
|
if(!rgszNames || cNames == 0 || !rgDispId)
|
||||||
|
return E_INVALIDARG;
|
||||||
|
|
||||||
|
hr = get_typeinfo(IServerXMLHTTPRequest_tid, &typeinfo);
|
||||||
|
if(SUCCEEDED(hr))
|
||||||
|
{
|
||||||
|
hr = ITypeInfo_GetIDsOfNames(typeinfo, rgszNames, cNames, rgDispId);
|
||||||
|
ITypeInfo_Release(typeinfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
return hr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI ServerXMLHTTPRequest_Invoke(IServerXMLHTTPRequest *iface, DISPID dispIdMember, REFIID riid,
|
static HRESULT WINAPI ServerXMLHTTPRequest_Invoke(IServerXMLHTTPRequest *iface, DISPID dispIdMember, REFIID riid,
|
||||||
@ -1621,11 +1634,21 @@ static HRESULT WINAPI ServerXMLHTTPRequest_Invoke(IServerXMLHTTPRequest *iface,
|
|||||||
EXCEPINFO *pExcepInfo, UINT *puArgErr)
|
EXCEPINFO *pExcepInfo, UINT *puArgErr)
|
||||||
{
|
{
|
||||||
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
serverhttp *This = impl_from_IServerXMLHTTPRequest( iface );
|
||||||
|
ITypeInfo *typeinfo;
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
FIXME("(%p)->(%d %s %d %d %p %p %p %p): stub\n", This, dispIdMember, debugstr_guid(riid),
|
TRACE("(%p)->(%d %s %d %d %p %p %p %p)\n", This, dispIdMember, debugstr_guid(riid),
|
||||||
lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
|
lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
|
||||||
|
|
||||||
return E_NOTIMPL;
|
hr = get_typeinfo(IServerXMLHTTPRequest_tid, &typeinfo);
|
||||||
|
if(SUCCEEDED(hr))
|
||||||
|
{
|
||||||
|
hr = ITypeInfo_Invoke(typeinfo, &This->IServerXMLHTTPRequest_iface, dispIdMember, wFlags,
|
||||||
|
pDispParams, pVarResult, pExcepInfo, puArgErr);
|
||||||
|
ITypeInfo_Release(typeinfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
return hr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI ServerXMLHTTPRequest_open(IServerXMLHTTPRequest *iface, BSTR method, BSTR url,
|
static HRESULT WINAPI ServerXMLHTTPRequest_open(IServerXMLHTTPRequest *iface, BSTR method, BSTR url,
|
||||||
|
@ -80,6 +80,7 @@ typedef enum tid_t {
|
|||||||
IMXReaderControl_tid,
|
IMXReaderControl_tid,
|
||||||
IMXWriter_tid,
|
IMXWriter_tid,
|
||||||
IVBMXNamespaceManager_tid,
|
IVBMXNamespaceManager_tid,
|
||||||
|
IServerXMLHTTPRequest_tid,
|
||||||
LAST_tid
|
LAST_tid
|
||||||
} tid_t;
|
} tid_t;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user