Commit 2907ad98 authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

msxml3: Avoid unneeded variant copy in setAttribute(), leak fixed as a side effect.

parent d4d92616
...@@ -1228,7 +1228,6 @@ static HRESULT WINAPI domelem_setAttribute( ...@@ -1228,7 +1228,6 @@ static HRESULT WINAPI domelem_setAttribute(
xmlChar *xml_name, *xml_value, *local, *prefix; xmlChar *xml_name, *xml_value, *local, *prefix;
xmlNodePtr element; xmlNodePtr element;
HRESULT hr; HRESULT hr;
VARIANT var;
TRACE("(%p)->(%s %s)\n", This, debugstr_w(name), debugstr_variant(&value)); TRACE("(%p)->(%s %s)\n", This, debugstr_w(name), debugstr_variant(&value));
...@@ -1236,16 +1235,25 @@ static HRESULT WINAPI domelem_setAttribute( ...@@ -1236,16 +1235,25 @@ static HRESULT WINAPI domelem_setAttribute(
if ( !element ) if ( !element )
return E_FAIL; return E_FAIL;
if (V_VT(&value) != VT_BSTR)
{
VARIANT var;
VariantInit(&var); VariantInit(&var);
hr = VariantChangeType(&var, &value, 0, VT_BSTR); hr = VariantChangeType(&var, &value, 0, VT_BSTR);
if(hr != S_OK) if (hr != S_OK)
{ {
FIXME("VariantChangeType failed\n"); FIXME("VariantChangeType failed\n");
return hr; return hr;
} }
xml_value = xmlchar_from_wchar(V_BSTR(&var));
VariantClear(&var);
}
else
xml_value = xmlchar_from_wchar(V_BSTR(&value));
xml_name = xmlchar_from_wchar( name ); xml_name = xmlchar_from_wchar( name );
xml_value = xmlchar_from_wchar( V_BSTR(&var) );
if ((local = xmlSplitQName2(xml_name, &prefix))) if ((local = xmlSplitQName2(xml_name, &prefix)))
{ {
...@@ -1268,7 +1276,6 @@ static HRESULT WINAPI domelem_setAttribute( ...@@ -1268,7 +1276,6 @@ static HRESULT WINAPI domelem_setAttribute(
heap_free(xml_value); heap_free(xml_value);
heap_free(xml_name); heap_free(xml_name);
VariantClear(&var);
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