Commit 0949cb45 authored by Alistair Leslie-Hughes's avatar Alistair Leslie-Hughes Committed by Alexandre Julliard

msado15: Add helper function to create CommandText interface.

parent 4981785f
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include "winbase.h" #include "winbase.h"
#define COBJMACROS #define COBJMACROS
#include "objbase.h" #include "objbase.h"
#include "msdasc.h"
#include "msado15_backcompat.h" #include "msado15_backcompat.h"
#include "wine/debug.h" #include "wine/debug.h"
......
...@@ -264,61 +264,90 @@ static HRESULT WINAPI connection_Close( _Connection *iface ) ...@@ -264,61 +264,90 @@ static HRESULT WINAPI connection_Close( _Connection *iface )
return S_OK; return S_OK;
} }
static HRESULT WINAPI connection_Execute( _Connection *iface, BSTR command, VARIANT *records_affected, HRESULT create_command_text(IUnknown *session, BSTR command, ICommandText **cmd_text)
LONG options, _Recordset **record_set )
{ {
struct connection *connection = impl_from_Connection( iface );
HRESULT hr; HRESULT hr;
IOpenRowset *openrowset; IOpenRowset *openrowset;
IDBCreateCommand *create_command = NULL; ICommandText *command_text;
ICommand *cmd = NULL; ICommand *cmd;
ICommandText *comand_text = NULL; IDBCreateCommand *create_command;
DBROWCOUNT affected;
IUnknown *rowset = NULL;
_Recordset *recordset = NULL;
ADORecordsetConstruction *construct;
FIXME( "%p, %s, %p, 0x%08x, %p Semi-stub\n", iface, debugstr_w(command), records_affected, options, record_set ); hr = IUnknown_QueryInterface(session, &IID_IOpenRowset, (void**)&openrowset);
if (connection->state == adStateClosed) return MAKE_ADO_HRESULT( adErrObjectClosed );
hr = IUnknown_QueryInterface(connection->session, &IID_IOpenRowset, (void**)&openrowset);
if (FAILED(hr)) if (FAILED(hr))
return hr; return hr;
hr = IOpenRowset_QueryInterface(openrowset, &IID_IDBCreateCommand, (void**)&create_command); hr = IOpenRowset_QueryInterface(openrowset, &IID_IDBCreateCommand, (void**)&create_command);
IOpenRowset_Release(openrowset);
if (FAILED(hr)) if (FAILED(hr))
goto done; return hr;
hr = IDBCreateCommand_CreateCommand(create_command, NULL, &IID_IUnknown, (IUnknown **)&cmd); hr = IDBCreateCommand_CreateCommand(create_command, NULL, &IID_IUnknown, (IUnknown **)&cmd);
IDBCreateCommand_Release(create_command);
if (FAILED(hr)) if (FAILED(hr))
goto done; return hr;
hr = ICommand_QueryInterface(cmd, &IID_ICommandText, (void**)&comand_text); hr = ICommand_QueryInterface(cmd, &IID_ICommandText, (void**)&command_text);
ICommand_Release(cmd);
if (FAILED(hr)) if (FAILED(hr))
{ {
FIXME("Currently only ICommandText interface is support\n"); FIXME("Currently only ICommandText interface is support\n");
goto done; return hr;
}
hr = ICommandText_SetCommandText(command_text, &DBGUID_DEFAULT, command);
if (FAILED(hr))
{
ICommandText_Release(command_text);
return hr;
} }
hr = ICommandText_SetCommandText(comand_text, &DBGUID_DEFAULT, command); *cmd_text = command_text;
return S_OK;
}
static HRESULT WINAPI connection_Execute( _Connection *iface, BSTR command, VARIANT *records_affected,
LONG options, _Recordset **record_set )
{
struct connection *connection = impl_from_Connection( iface );
HRESULT hr;
ICommandText *comand_text;
DBROWCOUNT affected;
IUnknown *rowset;
_Recordset *recordset;
ADORecordsetConstruction *construct;
FIXME( "%p, %s, %p, 0x%08x, %p Semi-stub\n", iface, debugstr_w(command), records_affected, options, record_set );
if (connection->state == adStateClosed) return MAKE_ADO_HRESULT( adErrObjectClosed );
hr = create_command_text(connection->session, command, &comand_text);
if (FAILED(hr)) if (FAILED(hr))
goto done; return hr;
hr = ICommandText_Execute(comand_text, NULL, &IID_IUnknown, NULL, &affected, &rowset); hr = ICommandText_Execute(comand_text, NULL, &IID_IUnknown, NULL, &affected, &rowset);
ICommandText_Release(comand_text);
if (FAILED(hr)) if (FAILED(hr))
goto done; return hr;
hr = Recordset_create( (void**)&recordset); hr = Recordset_create( (void**)&recordset);
if (FAILED(hr)) if (FAILED(hr))
goto done; {
IUnknown_Release(rowset);
return hr;
}
hr = _Recordset_QueryInterface(recordset, &IID_ADORecordsetConstruction, (void**)&construct); hr = _Recordset_QueryInterface(recordset, &IID_ADORecordsetConstruction, (void**)&construct);
if (FAILED(hr)) if (FAILED(hr))
goto done; {
IUnknown_Release(rowset);
_Recordset_Release(recordset);
return hr;
}
ADORecordsetConstruction_put_Rowset(construct, rowset); ADORecordsetConstruction_put_Rowset(construct, rowset);
ADORecordsetConstruction_Release(construct); ADORecordsetConstruction_Release(construct);
IUnknown_Release(rowset);
if (records_affected) if (records_affected)
{ {
...@@ -329,12 +358,6 @@ static HRESULT WINAPI connection_Execute( _Connection *iface, BSTR command, VARI ...@@ -329,12 +358,6 @@ static HRESULT WINAPI connection_Execute( _Connection *iface, BSTR command, VARI
_Recordset_put_CursorLocation(recordset, connection->location); _Recordset_put_CursorLocation(recordset, connection->location);
*record_set = recordset; *record_set = recordset;
done:
if (rowset) IUnknown_Release(rowset);
if (comand_text) ICommandText_Release(comand_text);
if (cmd) ICommand_Release(cmd);
if (create_command) IDBCreateCommand_Release(create_command);
if (openrowset) IOpenRowset_Release(openrowset);
return hr; return hr;
} }
......
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
#define COBJMACROS #define COBJMACROS
#include "objbase.h" #include "objbase.h"
#include "rpcproxy.h" #include "rpcproxy.h"
#include "msdasc.h"
#include "msado15_backcompat.h" #include "msado15_backcompat.h"
#include "wine/debug.h" #include "wine/debug.h"
......
...@@ -26,6 +26,8 @@ HRESULT Connection_create( void ** ) DECLSPEC_HIDDEN; ...@@ -26,6 +26,8 @@ HRESULT Connection_create( void ** ) DECLSPEC_HIDDEN;
HRESULT Recordset_create( void ** ) DECLSPEC_HIDDEN; HRESULT Recordset_create( void ** ) DECLSPEC_HIDDEN;
HRESULT Stream_create( void ** ) DECLSPEC_HIDDEN; HRESULT Stream_create( void ** ) DECLSPEC_HIDDEN;
HRESULT create_command_text(IUnknown *session, BSTR command, ICommandText **cmd_text) DECLSPEC_HIDDEN;
static inline void *heap_realloc_zero( void *mem, SIZE_T len ) static inline void *heap_realloc_zero( void *mem, SIZE_T len )
{ {
if (!mem) return HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, len ); if (!mem) return HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, len );
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include "winbase.h" #include "winbase.h"
#define COBJMACROS #define COBJMACROS
#include "objbase.h" #include "objbase.h"
#include "msdasc.h"
#include "msado15_backcompat.h" #include "msado15_backcompat.h"
#include "wine/debug.h" #include "wine/debug.h"
......
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