Commit f01a209e authored by Hans Leidekker's avatar Hans Leidekker Committed by Alexandre Julliard

webservices: Implement WsSetReaderPosition.

parent 5ad00660
...@@ -3979,3 +3979,20 @@ HRESULT WINAPI WsGetReaderPosition( WS_XML_READER *handle, WS_XML_NODE_POSITION ...@@ -3979,3 +3979,20 @@ HRESULT WINAPI WsGetReaderPosition( WS_XML_READER *handle, WS_XML_NODE_POSITION
pos->node = reader->current; pos->node = reader->current;
return S_OK; return S_OK;
} }
/**************************************************************************
* WsSetReaderPosition [webservices.@]
*/
HRESULT WINAPI WsSetReaderPosition( WS_XML_READER *handle, const WS_XML_NODE_POSITION *pos, WS_ERROR *error )
{
struct reader *reader = (struct reader *)handle;
TRACE( "%p %p %p\n", handle, pos, error );
if (error) FIXME( "ignoring error parameter\n" );
if (!reader || !pos || (struct xmlbuf *)pos->buffer != reader->input_buf) return E_INVALIDARG;
if (!reader->input_buf) return WS_E_INVALID_OPERATION;
reader->current = pos->node;
return S_OK;
}
...@@ -3495,6 +3495,53 @@ static void test_WsGetReaderPosition(void) ...@@ -3495,6 +3495,53 @@ static void test_WsGetReaderPosition(void)
WsFreeHeap( heap ); WsFreeHeap( heap );
} }
static void test_WsSetReaderPosition(void)
{
WS_HEAP *heap;
WS_XML_READER *reader;
WS_XML_BUFFER *buf1, *buf2;
WS_XML_NODE_POSITION pos;
HRESULT hr;
hr = WsCreateHeap( 1 << 16, 0, NULL, 0, &heap, NULL );
ok( hr == S_OK, "got %08x\n", hr );
hr = WsSetReaderPosition( NULL, NULL, NULL );
ok( hr == E_INVALIDARG, "got %08x\n", hr );
hr = WsCreateReader( NULL, 0, &reader, NULL ) ;
ok( hr == S_OK, "got %08x\n", hr );
hr = WsCreateXmlBuffer( heap, NULL, 0, &buf1, NULL );
ok( hr == S_OK, "got %08x\n", hr );
hr = WsSetInputToBuffer( reader, buf1, NULL, 0, NULL );
ok( hr == S_OK, "got %08x\n", hr );
hr = WsSetReaderPosition( reader, NULL, NULL );
ok( hr == E_INVALIDARG, "got %08x\n", hr );
pos.buffer = pos.node = NULL;
hr = WsGetReaderPosition( reader, &pos, NULL );
ok( hr == S_OK, "got %08x\n", hr );
ok( pos.buffer == buf1, "wrong buffer\n" );
ok( pos.node != NULL, "node not set\n" );
hr = WsSetReaderPosition( reader, &pos, NULL );
ok( hr == S_OK, "got %08x\n", hr );
/* different buffer */
hr = WsCreateXmlBuffer( heap, NULL, 0, &buf2, NULL );
ok( hr == S_OK, "got %08x\n", hr );
pos.buffer = buf2;
hr = WsSetReaderPosition( reader, &pos, NULL );
ok( hr == E_INVALIDARG, "got %08x\n", hr );
WsFreeReader( reader );
WsFreeHeap( heap );
}
START_TEST(reader) START_TEST(reader)
{ {
test_WsCreateError(); test_WsCreateError();
...@@ -3528,4 +3575,5 @@ START_TEST(reader) ...@@ -3528,4 +3575,5 @@ START_TEST(reader)
test_WsReadValue(); test_WsReadValue();
test_WsResetError(); test_WsResetError();
test_WsGetReaderPosition(); test_WsGetReaderPosition();
test_WsSetReaderPosition();
} }
...@@ -156,7 +156,7 @@ ...@@ -156,7 +156,7 @@
@ stdcall WsSetMessageProperty(ptr long ptr long ptr) @ stdcall WsSetMessageProperty(ptr long ptr long ptr)
@ stdcall WsSetOutput(ptr ptr ptr ptr long ptr) @ stdcall WsSetOutput(ptr ptr ptr ptr long ptr)
@ stdcall WsSetOutputToBuffer(ptr ptr ptr long ptr) @ stdcall WsSetOutputToBuffer(ptr ptr ptr long ptr)
@ stub WsSetReaderPosition @ stdcall WsSetReaderPosition(ptr ptr ptr)
@ stdcall WsSetWriterPosition(ptr ptr ptr) @ stdcall WsSetWriterPosition(ptr ptr ptr)
@ stub WsShutdownSessionChannel @ stub WsShutdownSessionChannel
@ stub WsSkipNode @ stub WsSkipNode
......
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