diff options
author | dan sinclair <dsinclair@chromium.org> | 2018-04-17 21:55:18 +0000 |
---|---|---|
committer | Chromium commit bot <commit-bot@chromium.org> | 2018-04-17 21:55:18 +0000 |
commit | 384e6fefb42ab5d3d71dd60f7f8d5f5155228804 (patch) | |
tree | 8fe0d065f51f6a459bd2be6adf625c3dd7a716f7 /core/fxcrt/xml/cfx_xmlelement.cpp | |
parent | 13aa65a71294cac6e4bdaab73ddd6f4b9fcd8676 (diff) | |
download | pdfium-384e6fefb42ab5d3d71dd60f7f8d5f5155228804.tar.xz |
CFX_XML Cleanup
Cleanup formatting and unused variables in the CFX_XML classes.
Change-Id: I1aff6317a3da38a141a071ba69c7893d0f669732
Reviewed-on: https://pdfium-review.googlesource.com/30730
Commit-Queue: dsinclair <dsinclair@chromium.org>
Reviewed-by: Henrique Nakashima <hnakashima@chromium.org>
Diffstat (limited to 'core/fxcrt/xml/cfx_xmlelement.cpp')
-rw-r--r-- | core/fxcrt/xml/cfx_xmlelement.cpp | 23 |
1 files changed, 14 insertions, 9 deletions
diff --git a/core/fxcrt/xml/cfx_xmlelement.cpp b/core/fxcrt/xml/cfx_xmlelement.cpp index d37c55c443..cab15f24c4 100644 --- a/core/fxcrt/xml/cfx_xmlelement.cpp +++ b/core/fxcrt/xml/cfx_xmlelement.cpp @@ -30,6 +30,8 @@ std::unique_ptr<CFX_XMLNode> CFX_XMLElement::Clone() { auto pClone = pdfium::MakeUnique<CFX_XMLElement>(name_); pClone->attrs_ = attrs_; + // TODO(dsinclair): This clone is wrong. It doesn't clone child nodes just + // copies text nodes? WideString wsText; for (CFX_XMLNode* pChild = GetFirstChild(); pChild; pChild = pChild->GetNextSibling()) { @@ -52,26 +54,26 @@ WideString CFX_XMLElement::GetNamespacePrefix() const { } WideString CFX_XMLElement::GetNamespaceURI() const { - WideString wsAttri(L"xmlns"); + WideString attr(L"xmlns"); WideString wsPrefix = GetNamespacePrefix(); - if (wsPrefix.GetLength() > 0) { - wsAttri += L":"; - wsAttri += wsPrefix; + if (!wsPrefix.IsEmpty()) { + attr += L":"; + attr += wsPrefix; } - auto* pNode = static_cast<const CFX_XMLNode*>(this); + const CFX_XMLNode* pNode = this; while (pNode) { if (pNode->GetType() != FX_XMLNODE_Element) break; auto* pElement = static_cast<const CFX_XMLElement*>(pNode); - if (!pElement->HasAttribute(wsAttri)) { + if (!pElement->HasAttribute(attr)) { pNode = pNode->GetParent(); continue; } - return pElement->GetAttribute(wsAttri); + return pElement->GetAttribute(attr); } - return WideString(); + return L""; } WideString CFX_XMLElement::GetTextData() const { @@ -88,7 +90,8 @@ WideString CFX_XMLElement::GetTextData() const { } void CFX_XMLElement::SetTextData(const WideString& wsText) { - if (wsText.GetLength() < 1) + // TODO(dsinclair): Shouldn't this remove the children if you set blank text? + if (wsText.IsEmpty()) return; AppendChild(pdfium::MakeUnique<CFX_XMLText>(wsText)); } @@ -100,6 +103,8 @@ void CFX_XMLElement::Save(const RetainPtr<IFX_SeekableStream>& pXMLStream) { pXMLStream->WriteString(name_encoded); for (auto it : attrs_) { + // Note, the space between attributes is added by AttributeToString which + // writes a blank as the first character. pXMLStream->WriteString( AttributeToString(it.first, it.second).UTF8Encode().AsStringView()); } |