Commit 6e351769 authored by Alistair Leslie-Hughes's avatar Alistair Leslie-Hughes Committed by Alexandre Julliard

msdasql: Add IDBInitialize support.

parent 91669063
...@@ -104,6 +104,7 @@ struct msdasql ...@@ -104,6 +104,7 @@ struct msdasql
{ {
IUnknown MSDASQL_iface; IUnknown MSDASQL_iface;
IDBProperties IDBProperties_iface; IDBProperties IDBProperties_iface;
IDBInitialize IDBInitialize_iface;
LONG ref; LONG ref;
}; };
...@@ -118,6 +119,11 @@ static inline struct msdasql *impl_from_IDBProperties(IDBProperties *iface) ...@@ -118,6 +119,11 @@ static inline struct msdasql *impl_from_IDBProperties(IDBProperties *iface)
return CONTAINING_RECORD(iface, struct msdasql, IDBProperties_iface); return CONTAINING_RECORD(iface, struct msdasql, IDBProperties_iface);
} }
static inline struct msdasql *impl_from_IDBInitialize(IDBInitialize *iface)
{
return CONTAINING_RECORD(iface, struct msdasql, IDBInitialize_iface);
}
static HRESULT WINAPI msdsql_QueryInterface(IUnknown *iface, REFIID riid, void **out) static HRESULT WINAPI msdsql_QueryInterface(IUnknown *iface, REFIID riid, void **out)
{ {
struct msdasql *provider = impl_from_IUnknown(iface); struct msdasql *provider = impl_from_IUnknown(iface);
...@@ -133,6 +139,10 @@ static HRESULT WINAPI msdsql_QueryInterface(IUnknown *iface, REFIID riid, void * ...@@ -133,6 +139,10 @@ static HRESULT WINAPI msdsql_QueryInterface(IUnknown *iface, REFIID riid, void *
{ {
*out = &provider->IDBProperties_iface; *out = &provider->IDBProperties_iface;
} }
else if ( IsEqualGUID(riid, &IID_IDBInitialize))
{
*out = &provider->IDBInitialize_iface;
}
else else
{ {
FIXME("(%s, %p)\n", debugstr_guid(riid), out); FIXME("(%s, %p)\n", debugstr_guid(riid), out);
...@@ -239,6 +249,55 @@ static const struct IDBPropertiesVtbl dbprops_vtbl = ...@@ -239,6 +249,55 @@ static const struct IDBPropertiesVtbl dbprops_vtbl =
dbprops_SetProperties dbprops_SetProperties
}; };
static HRESULT WINAPI dbinit_QueryInterface(IDBInitialize *iface, REFIID riid, void **ppvObject)
{
struct msdasql *provider = impl_from_IDBInitialize(iface);
return IUnknown_QueryInterface(&provider->MSDASQL_iface, riid, ppvObject);
}
static ULONG WINAPI dbinit_AddRef(IDBInitialize *iface)
{
struct msdasql *provider = impl_from_IDBInitialize(iface);
return IUnknown_AddRef(&provider->MSDASQL_iface);
}
static ULONG WINAPI dbinit_Release(IDBInitialize *iface)
{
struct msdasql *provider = impl_from_IDBInitialize(iface);
return IUnknown_Release(&provider->MSDASQL_iface);
}
static HRESULT WINAPI dbinit_Initialize(IDBInitialize *iface)
{
struct msdasql *provider = impl_from_IDBInitialize(iface);
FIXME("%p stub\n", provider);
return S_OK;
}
static HRESULT WINAPI dbinit_Uninitialize(IDBInitialize *iface)
{
struct msdasql *provider = impl_from_IDBInitialize(iface);
FIXME("%p stub\n", provider);
return S_OK;
}
static const struct IDBInitializeVtbl dbinit_vtbl =
{
dbinit_QueryInterface,
dbinit_AddRef,
dbinit_Release,
dbinit_Initialize,
dbinit_Uninitialize
};
static HRESULT create_msdasql_provider(REFIID riid, void **ppv) static HRESULT create_msdasql_provider(REFIID riid, void **ppv)
{ {
struct msdasql *provider; struct msdasql *provider;
...@@ -250,6 +309,7 @@ static HRESULT create_msdasql_provider(REFIID riid, void **ppv) ...@@ -250,6 +309,7 @@ static HRESULT create_msdasql_provider(REFIID riid, void **ppv)
provider->MSDASQL_iface.lpVtbl = &msdsql_vtbl; provider->MSDASQL_iface.lpVtbl = &msdsql_vtbl;
provider->IDBProperties_iface.lpVtbl = &dbprops_vtbl; provider->IDBProperties_iface.lpVtbl = &dbprops_vtbl;
provider->IDBInitialize_iface.lpVtbl = &dbinit_vtbl;
provider->ref = 1; provider->ref = 1;
hr = IUnknown_QueryInterface(&provider->MSDASQL_iface, riid, ppv); hr = IUnknown_QueryInterface(&provider->MSDASQL_iface, riid, ppv);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment