summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNoel <noelgrandin@gmail.com>2020-12-15 15:41:39 +0200
committerNoel Grandin <noel.grandin@collabora.co.uk>2020-12-17 09:43:09 +0100
commit6e1cbf1cfa047007d048a70c6bf3abe67866f65d (patch)
treea10100af444c90f56babb866db7bbbb8fa102729
parentd8b01ac94c8ebd55bef6d00cbfa34775ea07271f (diff)
use views to parse
Change-Id: I6c396d37df3c0c823e9cf61738825a126e1a2cb7 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/107763 Tested-by: Jenkins Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
-rw-r--r--xmloff/source/text/txtparai.cxx45
1 files changed, 19 insertions, 26 deletions
diff --git a/xmloff/source/text/txtparai.cxx b/xmloff/source/text/txtparai.cxx
index 2319af663736..c3ef3d9b3e7f 100644
--- a/xmloff/source/text/txtparai.cxx
+++ b/xmloff/source/text/txtparai.cxx
@@ -661,7 +661,7 @@ public:
virtual void SAL_CALL characters( const OUString& i_rChars ) override;
- virtual void ProcessAttribute(sal_Int32 nAttributeToken, OUString const & i_rValue);
+ virtual void ProcessAttribute(const sax_fastparser::FastAttributeList::FastAttributeIter & aIter);
virtual void InsertMeta(const Reference<XTextRange> & i_xInsertionRange)
= 0;
@@ -686,7 +686,7 @@ void XMLMetaImportContextBase::startFastElement(
const Reference<xml::sax::XFastAttributeList> & xAttrList)
{
for (auto &aIter : sax_fastparser::castToFastAttributeList( xAttrList ))
- ProcessAttribute(aIter.getToken(), aIter.toString());
+ ProcessAttribute(aIter);
}
void XMLMetaImportContextBase::endFastElement(sal_Int32 )
@@ -719,13 +719,12 @@ void XMLMetaImportContextBase::characters( const OUString& i_rChars )
GetImport().GetTextImport()->InsertString(i_rChars, m_rIgnoreLeadingSpace);
}
-void XMLMetaImportContextBase::ProcessAttribute(sal_Int32 nAttributeToken,
- OUString const & i_rValue)
+void XMLMetaImportContextBase::ProcessAttribute(const sax_fastparser::FastAttributeList::FastAttributeIter & aIter)
{
- if ( nAttributeToken == XML_ELEMENT(XML, XML_ID) )
- m_XmlId = i_rValue;
+ if ( aIter.getToken() == XML_ELEMENT(XML, XML_ID) )
+ m_XmlId = aIter.toString();
else
- XMLOFF_WARN_UNKNOWN_ATTR("xmloff", nAttributeToken, i_rValue);
+ XMLOFF_WARN_UNKNOWN("xmloff", aIter);
}
namespace {
@@ -748,8 +747,7 @@ public:
XMLHints_Impl& i_rHints,
bool & i_rIgnoreLeadingSpace );
- virtual void ProcessAttribute(sal_Int32 nAttributeToken,
- OUString const & i_rValue) override;
+ virtual void ProcessAttribute(const sax_fastparser::FastAttributeList::FastAttributeIter & aIter) override;
virtual void InsertMeta(const Reference<XTextRange> & i_xInsertionRange) override;
};
@@ -767,28 +765,26 @@ XMLMetaImportContext::XMLMetaImportContext(
{
}
-void XMLMetaImportContext::ProcessAttribute(sal_Int32 nAttributeToken,
- OUString const & i_rValue)
+void XMLMetaImportContext::ProcessAttribute(const sax_fastparser::FastAttributeList::FastAttributeIter & aIter)
{
- switch (nAttributeToken)
+ switch (aIter.getToken())
{
// RDFa
case XML_ELEMENT(XHTML, XML_ABOUT):
- m_sAbout = i_rValue;
+ m_sAbout = aIter.toString();
m_bHaveAbout = true;
break;
case XML_ELEMENT(XHTML, XML_PROPERTY):
- m_sProperty = i_rValue;
+ m_sProperty = aIter.toString();
break;
case XML_ELEMENT(XHTML, XML_CONTENT):
- m_sContent = i_rValue;
+ m_sContent = aIter.toString();
break;
case XML_ELEMENT(XHTML, XML_DATATYPE):
- m_sDatatype = i_rValue;
+ m_sDatatype = aIter.toString();
break;
default:
- XMLMetaImportContextBase::ProcessAttribute(
- nAttributeToken, i_rValue);
+ XMLMetaImportContextBase::ProcessAttribute(aIter);
}
}
@@ -835,8 +831,7 @@ public:
XMLHints_Impl& i_rHints,
bool & i_rIgnoreLeadingSpace );
- virtual void ProcessAttribute(sal_Int32 nAttributeToken,
- OUString const & i_rValue) override;
+ virtual void ProcessAttribute(const sax_fastparser::FastAttributeList::FastAttributeIter & aIter) override;
virtual void InsertMeta(const Reference<XTextRange> & i_xInsertionRange) override;
};
@@ -853,17 +848,15 @@ XMLMetaFieldImportContext::XMLMetaFieldImportContext(
{
}
-void XMLMetaFieldImportContext::ProcessAttribute(sal_Int32 nAttributeToken,
- OUString const & i_rValue)
+void XMLMetaFieldImportContext::ProcessAttribute(const sax_fastparser::FastAttributeList::FastAttributeIter & aIter)
{
- switch (nAttributeToken)
+ switch (aIter.getToken())
{
case XML_ELEMENT(STYLE, XML_DATA_STYLE_NAME):
- m_DataStyleName = i_rValue;
+ m_DataStyleName = aIter.toString();
break;
default:
- XMLMetaImportContextBase::ProcessAttribute(
- nAttributeToken, i_rValue);
+ XMLMetaImportContextBase::ProcessAttribute(aIter);
}
}