msxml3: Don't allocate new strings when returning namespace related data.

This commit is contained in:
Piotr Caban 2011-10-31 12:33:08 +01:00 committed by Alexandre Julliard
parent 619c2dcd08
commit 216b64801d
1 changed files with 23 additions and 9 deletions

View File

@ -313,6 +313,20 @@ static HRESULT namespacePop(saxlocator *locator)
return S_OK; return S_OK;
} }
static BSTR namespaceFind(saxlocator *locator, const xmlChar *ptr)
{
int i;
for(i=locator->nsStackLast-1; i>=0; i--)
{
if(ptr == locator->nsStack[i].ptr)
return locator->nsStack[i].uri;
}
ERR("namespace not found\n");
return NULL;
}
static BOOL bstr_pool_insert(struct bstrpool *pool, BSTR pool_entry) static BOOL bstr_pool_insert(struct bstrpool *pool, BSTR pool_entry)
{ {
if (!pool->pool) if (!pool->pool)
@ -1188,7 +1202,7 @@ static void libxmlStartElementNS(
int nb_defaulted, int nb_defaulted,
const xmlChar **attributes) const xmlChar **attributes)
{ {
BSTR NamespaceUri, LocalName, QName, Prefix, Uri; BSTR NamespaceUri, LocalName, QName;
saxlocator *This = ctx; saxlocator *This = ctx;
HRESULT hr; HRESULT hr;
int index; int index;
@ -1214,18 +1228,18 @@ static void libxmlStartElementNS(
{ {
for(index=0; index<nb_namespaces; index++) for(index=0; index<nb_namespaces; index++)
{ {
Prefix = pooled_bstr_from_xmlChar(&This->saxreader->pool, namespaces[2*index]);
Uri = pooled_bstr_from_xmlChar(&This->saxreader->pool, namespaces[2*index+1]);
if(This->vbInterface) if(This->vbInterface)
hr = IVBSAXContentHandler_startPrefixMapping( hr = IVBSAXContentHandler_startPrefixMapping(
This->saxreader->vbcontentHandler, This->saxreader->vbcontentHandler,
&Prefix, &Uri); &This->nsStack[This->nsStackLast-nb_namespaces+index].prefix,
&This->nsStack[This->nsStackLast-nb_namespaces+index].uri);
else else
hr = ISAXContentHandler_startPrefixMapping( hr = ISAXContentHandler_startPrefixMapping(
This->saxreader->contentHandler, This->saxreader->contentHandler,
Prefix, SysStringLen(Prefix), This->nsStack[This->nsStackLast-nb_namespaces+index].prefix,
Uri, SysStringLen(Uri)); SysStringLen(This->nsStack[This->nsStackLast-nb_namespaces+index].prefix),
This->nsStack[This->nsStackLast-nb_namespaces+index].uri,
SysStringLen(This->nsStack[This->nsStackLast-nb_namespaces+index].uri));
if(This->saxreader->version>=MSXML6 ? FAILED(hr) : hr!=S_OK) if(This->saxreader->version>=MSXML6 ? FAILED(hr) : hr!=S_OK)
{ {
@ -1234,7 +1248,7 @@ static void libxmlStartElementNS(
} }
} }
NamespaceUri = pooled_bstr_from_xmlChar(&This->saxreader->pool, URI); NamespaceUri = namespaceFind(This, URI);
LocalName = pooled_bstr_from_xmlChar(&This->saxreader->pool, localname); LocalName = pooled_bstr_from_xmlChar(&This->saxreader->pool, localname);
QName = pooled_QName_from_xmlChar(&This->saxreader->pool, prefix, localname); QName = pooled_QName_from_xmlChar(&This->saxreader->pool, prefix, localname);
@ -1280,7 +1294,7 @@ static void libxmlEndElementNS(
if(has_content_handler(This)) if(has_content_handler(This))
{ {
NamespaceUri = pooled_bstr_from_xmlChar(&This->saxreader->pool, URI); NamespaceUri = namespaceFind(This, URI);
LocalName = pooled_bstr_from_xmlChar(&This->saxreader->pool, localname); LocalName = pooled_bstr_from_xmlChar(&This->saxreader->pool, localname);
QName = pooled_QName_from_xmlChar(&This->saxreader->pool, prefix, localname); QName = pooled_QName_from_xmlChar(&This->saxreader->pool, prefix, localname);