Hans Leidekker : webservices: Implement WS_MOVE_TO_PARENT_ELEMENT in the reader.
Module: wine Branch: master Commit: 57a7870649e819f5a408b5e737dfd6001c8fd8d3 URL: http://source.winehq.org/git/wine.git/?a=commit;h=57a7870649e819f5a408b5e737... Author: Hans Leidekker <hans(a)codeweavers.com> Date: Wed Feb 10 15:02:07 2016 +0100 webservices: Implement WS_MOVE_TO_PARENT_ELEMENT in the reader. Signed-off-by: Hans Leidekker <hans(a)codeweavers.com> Signed-off-by: Alexandre Julliard <julliard(a)winehq.org> --- dlls/webservices/reader.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/dlls/webservices/reader.c b/dlls/webservices/reader.c index 1979ad7..55cd4ac 100644 --- a/dlls/webservices/reader.c +++ b/dlls/webservices/reader.c @@ -1424,6 +1424,19 @@ static BOOL move_to_end_element( struct reader *reader ) return FALSE; } +static BOOL move_to_parent_element( struct reader *reader ) +{ + struct node *parent = reader->current->parent; + + if (parent && (parent->hdr.node.nodeType == WS_XML_NODE_TYPE_ELEMENT || + parent->hdr.node.nodeType == WS_XML_NODE_TYPE_BOF)) + { + reader->current = parent; + return TRUE; + } + return FALSE; +} + static HRESULT read_move_to( struct reader *reader, WS_MOVE_TO move, BOOL *found ) { struct list *ptr; @@ -1457,6 +1470,10 @@ static HRESULT read_move_to( struct reader *reader, WS_MOVE_TO move, BOOL *found success = move_to_end_element( reader ); break; + case WS_MOVE_TO_PARENT_ELEMENT: + success = move_to_parent_element( reader ); + break; + case WS_MOVE_TO_FIRST_NODE: if ((ptr = list_head( &reader->current->parent->children ))) {
participants (1)
-
Alexandre Julliard