Commit afad45ff authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

msxml3: Use libxml2 functionality to skip top XML declaration node while writing to file.

parent ecb2d7bd
...@@ -47,6 +47,8 @@ WINE_DEFAULT_DEBUG_CHANNEL(msxml); ...@@ -47,6 +47,8 @@ WINE_DEFAULT_DEBUG_CHANNEL(msxml);
#ifdef HAVE_LIBXML2 #ifdef HAVE_LIBXML2
#include <libxml/xmlsave.h>
static const WCHAR SZ_PROPERTY_SELECTION_LANGUAGE[] = {'S','e','l','e','c','t','i','o','n','L','a','n','g','u','a','g','e',0}; static const WCHAR SZ_PROPERTY_SELECTION_LANGUAGE[] = {'S','e','l','e','c','t','i','o','n','L','a','n','g','u','a','g','e',0};
static const WCHAR SZ_VALUE_XPATH[] = {'X','P','a','t','h',0}; static const WCHAR SZ_VALUE_XPATH[] = {'X','P','a','t','h',0};
static const WCHAR SZ_VALUE_XSLPATTERN[] = {'X','S','L','P','a','t','t','e','r','n',0}; static const WCHAR SZ_VALUE_XSLPATTERN[] = {'X','S','L','P','a','t','t','e','r','n',0};
...@@ -1651,6 +1653,24 @@ static HRESULT WINAPI domdoc_loadXML( ...@@ -1651,6 +1653,24 @@ static HRESULT WINAPI domdoc_loadXML(
return hr; return hr;
} }
static int XMLCALL domdoc_save_writecallback(void *ctx, const char *buffer,
int len)
{
DWORD written = -1;
if(!WriteFile(ctx, buffer, len, &written, NULL))
{
WARN("write error\n");
return -1;
}
else
return written;
}
static int XMLCALL domdoc_save_closecallback(void *ctx)
{
return CloseHandle(ctx) ? 0 : -1;
}
static HRESULT WINAPI domdoc_save( static HRESULT WINAPI domdoc_save(
IXMLDOMDocument2 *iface, IXMLDOMDocument2 *iface,
...@@ -1658,10 +1678,8 @@ static HRESULT WINAPI domdoc_save( ...@@ -1658,10 +1678,8 @@ static HRESULT WINAPI domdoc_save(
{ {
domdoc *This = impl_from_IXMLDOMDocument2( iface ); domdoc *This = impl_from_IXMLDOMDocument2( iface );
HANDLE handle; HANDLE handle;
xmlChar *mem, *p; xmlSaveCtxtPtr ctx;
int size;
HRESULT ret = S_OK; HRESULT ret = S_OK;
DWORD written;
TRACE("(%p)->(var(vt %d, %s))\n", This, V_VT(&destination), TRACE("(%p)->(var(vt %d, %s))\n", This, V_VT(&destination),
V_VT(&destination) == VT_BSTR ? debugstr_w(V_BSTR(&destination)) : NULL); V_VT(&destination) == VT_BSTR ? debugstr_w(V_BSTR(&destination)) : NULL);
...@@ -1707,31 +1725,19 @@ static HRESULT WINAPI domdoc_save( ...@@ -1707,31 +1725,19 @@ static HRESULT WINAPI domdoc_save(
return S_FALSE; return S_FALSE;
} }
xmlDocDumpMemory(get_doc(This), &mem, &size); /* disable top XML declaration */
ctx = xmlSaveToIO(domdoc_save_writecallback, domdoc_save_closecallback,
/* handle, NULL, XML_SAVE_NO_DECL);
* libxml2 always adds XML declaration on top of the file and one for each processing instruction node in DOM tree. if (!ctx)
* MSXML adds XML declaration only for processing instruction nodes.
* We skip the first XML declaration generated by libxml2 to get exactly what we need.
*/
p = mem;
if(size > 2 && p[0] == '<' && p[1] == '?') {
while(p < mem+size && (p[0] != '?' || p[1] != '>'))
p++;
p += 2;
while(p < mem+size && isspace(*p))
p++;
size -= p-mem;
}
if(!WriteFile(handle, p, (DWORD)size, &written, NULL) || written != (DWORD)size)
{ {
WARN("write error\n"); CloseHandle(handle);
ret = S_FALSE; return S_FALSE;
} }
xmlFree(mem); if (xmlSaveDoc(ctx, get_doc(This)) == -1) ret = S_FALSE;
CloseHandle(handle); /* will close file through close callback */
xmlSaveClose(ctx);
return ret; return ret;
} }
......
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