Commit 6917e2aa authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

xmllite: Clear all parser values in SetInput.

Not clearing namespaces was problematic for tests, but clearing other values also looks like a good idea. Signed-off-by: 's avatarJacek Caban <jacek@codeweavers.com> Signed-off-by: 's avatarNikolay Sivov <nsivov@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 82f95833
...@@ -2679,17 +2679,36 @@ static void reader_clear_ns(xmlreader *reader) ...@@ -2679,17 +2679,36 @@ static void reader_clear_ns(xmlreader *reader)
struct ns *ns, *ns2; struct ns *ns, *ns2;
LIST_FOR_EACH_ENTRY_SAFE(ns, ns2, &reader->ns, struct ns, entry) { LIST_FOR_EACH_ENTRY_SAFE(ns, ns2, &reader->ns, struct ns, entry) {
list_remove(&ns->entry);
reader_free_strvalued(reader, &ns->prefix); reader_free_strvalued(reader, &ns->prefix);
reader_free_strvalued(reader, &ns->uri); reader_free_strvalued(reader, &ns->uri);
reader_free(reader, ns); reader_free(reader, ns);
} }
LIST_FOR_EACH_ENTRY_SAFE(ns, ns2, &reader->nsdef, struct ns, entry) { LIST_FOR_EACH_ENTRY_SAFE(ns, ns2, &reader->nsdef, struct ns, entry) {
list_remove(&ns->entry);
reader_free_strvalued(reader, &ns->uri); reader_free_strvalued(reader, &ns->uri);
reader_free(reader, ns); reader_free(reader, ns);
} }
} }
static void reader_reset_parser(xmlreader *reader)
{
reader->position.line_number = 0;
reader->position.line_position = 0;
reader_clear_elements(reader);
reader_clear_attrs(reader);
reader_clear_ns(reader);
reader_free_strvalues(reader);
reader->depth = 0;
reader->nodetype = XmlNodeType_None;
reader->resumestate = XmlReadResumeState_Initial;
memset(reader->resume, 0, sizeof(reader->resume));
reader->is_empty_element = FALSE;
}
static ULONG WINAPI xmlreader_Release(IXmlReader *iface) static ULONG WINAPI xmlreader_Release(IXmlReader *iface)
{ {
xmlreader *This = impl_from_IXmlReader(iface); xmlreader *This = impl_from_IXmlReader(iface);
...@@ -2700,13 +2719,10 @@ static ULONG WINAPI xmlreader_Release(IXmlReader *iface) ...@@ -2700,13 +2719,10 @@ static ULONG WINAPI xmlreader_Release(IXmlReader *iface)
if (ref == 0) if (ref == 0)
{ {
IMalloc *imalloc = This->imalloc; IMalloc *imalloc = This->imalloc;
reader_reset_parser(This);
if (This->input) IUnknown_Release(&This->input->IXmlReaderInput_iface); if (This->input) IUnknown_Release(&This->input->IXmlReaderInput_iface);
if (This->resolver) IXmlResolver_Release(This->resolver); if (This->resolver) IXmlResolver_Release(This->resolver);
if (This->mlang) IUnknown_Release(This->mlang); if (This->mlang) IUnknown_Release(This->mlang);
reader_clear_attrs(This);
reader_clear_ns(This);
reader_clear_elements(This);
reader_free_strvalues(This);
reader_free(This, This); reader_free(This, This);
if (imalloc) IMalloc_Release(imalloc); if (imalloc) IMalloc_Release(imalloc);
} }
...@@ -2729,13 +2745,7 @@ static HRESULT WINAPI xmlreader_SetInput(IXmlReader* iface, IUnknown *input) ...@@ -2729,13 +2745,7 @@ static HRESULT WINAPI xmlreader_SetInput(IXmlReader* iface, IUnknown *input)
This->input = NULL; This->input = NULL;
} }
This->position.line_number = 0; reader_reset_parser(This);
This->position.line_position = 0;
reader_clear_elements(This);
This->depth = 0;
This->nodetype = XmlNodeType_None;
This->resumestate = XmlReadResumeState_Initial;
memset(This->resume, 0, sizeof(This->resume));
/* just reset current input */ /* just reset current input */
if (!input) if (!input)
...@@ -2776,7 +2786,6 @@ static HRESULT WINAPI xmlreader_SetInput(IXmlReader* iface, IUnknown *input) ...@@ -2776,7 +2786,6 @@ static HRESULT WINAPI xmlreader_SetInput(IXmlReader* iface, IUnknown *input)
This->state = XmlReadState_Initial; This->state = XmlReadState_Initial;
This->instate = XmlReadInState_Initial; This->instate = XmlReadInState_Initial;
} }
return hr; return hr;
} }
......
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