From 7ca47d55c9cbbec7e0a0b0beffffe348ae655086 Mon Sep 17 00:00:00 2001 From: Henrique Nakashima Date: Fri, 16 Jun 2017 12:00:40 -0400 Subject: Converting CFX_ByteTextBuf to ostringstream in SAX. Bug: pdfium:731 Change-Id: Ic492e8900c4a69082ff9c2384006a4e6bfa3313e Reviewed-on: https://pdfium-review.googlesource.com/6592 Reviewed-by: Lei Zhang Reviewed-by: dsinclair Commit-Queue: Henrique Nakashima --- BUILD.gn | 1 + core/fxcrt/xml/cfx_saxcontext.cpp | 9 +++++++++ core/fxcrt/xml/cfx_saxcontext.h | 7 +++++-- core/fxcrt/xml/cfx_saxreaderhandler.cpp | 34 ++++++++++++++++----------------- 4 files changed, 31 insertions(+), 20 deletions(-) create mode 100644 core/fxcrt/xml/cfx_saxcontext.cpp diff --git a/BUILD.gn b/BUILD.gn index ecc8f6a51e..2c038b29c8 100644 --- a/BUILD.gn +++ b/BUILD.gn @@ -874,6 +874,7 @@ static_library("fxcrt") { "core/fxcrt/fx_arabic.h", "core/fxcrt/ifx_chariter.h", "core/fxcrt/ifx_locale.h", + "core/fxcrt/xml/cfx_saxcontext.cpp", "core/fxcrt/xml/cfx_saxcontext.h", "core/fxcrt/xml/cfx_saxreader.cpp", "core/fxcrt/xml/cfx_saxreader.h", diff --git a/core/fxcrt/xml/cfx_saxcontext.cpp b/core/fxcrt/xml/cfx_saxcontext.cpp new file mode 100644 index 0000000000..4e2f0c58c9 --- /dev/null +++ b/core/fxcrt/xml/cfx_saxcontext.cpp @@ -0,0 +1,9 @@ +// Copyright 2017 PDFium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "core/fxcrt/xml/cfx_saxcontext.h" + +CFX_SAXContext::CFX_SAXContext() : m_eNode(CFX_SAXItem::Type::Unknown) {} + +CFX_SAXContext::~CFX_SAXContext() {} diff --git a/core/fxcrt/xml/cfx_saxcontext.h b/core/fxcrt/xml/cfx_saxcontext.h index 7afebed98d..fcc889f7a3 100644 --- a/core/fxcrt/xml/cfx_saxcontext.h +++ b/core/fxcrt/xml/cfx_saxcontext.h @@ -7,15 +7,18 @@ #ifndef CORE_FXCRT_XML_CFX_SAXCONTEXT_H_ #define CORE_FXCRT_XML_CFX_SAXCONTEXT_H_ +#include + #include "core/fxcrt/fx_basic.h" #include "core/fxcrt/fx_string.h" #include "core/fxcrt/xml/cfx_saxreader.h" class CFX_SAXContext { public: - CFX_SAXContext() : m_eNode(CFX_SAXItem::Type::Unknown) {} + CFX_SAXContext(); + ~CFX_SAXContext(); - CFX_ByteTextBuf m_TextBuf; + std::ostringstream m_TextBuf; CFX_ByteString m_bsTagName; CFX_SAXItem::Type m_eNode; }; diff --git a/core/fxcrt/xml/cfx_saxreaderhandler.cpp b/core/fxcrt/xml/cfx_saxreaderhandler.cpp index e7b6cd186c..9967f3eea8 100644 --- a/core/fxcrt/xml/cfx_saxreaderhandler.cpp +++ b/core/fxcrt/xml/cfx_saxreaderhandler.cpp @@ -26,12 +26,11 @@ CFX_SAXContext* CFX_SAXReaderHandler::OnTagEnter( } m_SAXContext.m_eNode = eType; - CFX_ByteTextBuf& textBuf = m_SAXContext.m_TextBuf; - textBuf << "<"; + m_SAXContext.m_TextBuf << "<"; if (eType == CFX_SAXItem::Type::Instruction) - textBuf << "?"; + m_SAXContext.m_TextBuf << "?"; - textBuf << bsTagName; + m_SAXContext.m_TextBuf << bsTagName.c_str(); m_SAXContext.m_bsTagName = bsTagName; return &m_SAXContext; } @@ -41,7 +40,7 @@ void CFX_SAXReaderHandler::OnTagAttribute(CFX_SAXContext* pTag, const CFX_ByteStringC& bsValue) { if (!pTag) return; - pTag->m_TextBuf << " " << bsAttri << "=\"" << bsValue << "\""; + pTag->m_TextBuf << " " << bsAttri.c_str() << "=\"" << bsValue.c_str() << "\""; } void CFX_SAXReaderHandler::OnTagBreak(CFX_SAXContext* pTag) { @@ -59,24 +58,22 @@ void CFX_SAXReaderHandler::OnTagData(CFX_SAXContext* pTag, if (!pTag) return; - CFX_ByteTextBuf& textBuf = pTag->m_TextBuf; if (eType == CFX_SAXItem::Type::CharData) - textBuf << "m_TextBuf << "m_TextBuf << bsData.c_str(); if (eType == CFX_SAXItem::Type::CharData) - textBuf << "]]>"; + pTag->m_TextBuf << "]]>"; } void CFX_SAXReaderHandler::OnTagClose(CFX_SAXContext* pTag, uint32_t dwEndPos) { if (!pTag) return; - CFX_ByteTextBuf& textBuf = pTag->m_TextBuf; if (pTag->m_eNode == CFX_SAXItem::Type::Instruction) - textBuf << "?>"; + pTag->m_TextBuf << "?>"; else if (pTag->m_eNode == CFX_SAXItem::Type::Tag) - textBuf << ">m_bsTagName.AsStringC() << ">"; + pTag->m_TextBuf << ">m_bsTagName.AsStringC().c_str() << ">"; UpdateChecksum(false); } @@ -87,7 +84,7 @@ void CFX_SAXReaderHandler::OnTagEnd(CFX_SAXContext* pTag, if (!pTag) return; - pTag->m_TextBuf << ""; + pTag->m_TextBuf << ""; UpdateChecksum(false); } @@ -99,19 +96,20 @@ void CFX_SAXReaderHandler::OnTargetData(CFX_SAXContext* pTag, return; if (eType == CFX_SAXItem::Type::Comment) { - m_SAXContext.m_TextBuf << ""; + m_SAXContext.m_TextBuf << ""; UpdateChecksum(false); } else { - pTag->m_TextBuf << " " << bsData; + pTag->m_TextBuf << " " << bsData.c_str(); } } void CFX_SAXReaderHandler::UpdateChecksum(bool bCheckSpace) { - int32_t iLength = m_SAXContext.m_TextBuf.GetLength(); + int32_t iLength = m_SAXContext.m_TextBuf.tellp(); if (iLength < 1) return; - uint8_t* pBuffer = m_SAXContext.m_TextBuf.GetBuffer(); + const uint8_t* pBuffer = + reinterpret_cast(m_SAXContext.m_TextBuf.str().c_str()); bool bUpdata = true; if (bCheckSpace) { bUpdata = false; @@ -124,5 +122,5 @@ void CFX_SAXReaderHandler::UpdateChecksum(bool bCheckSpace) { if (bUpdata) m_pContext->Update(CFX_ByteStringC(pBuffer, iLength)); - m_SAXContext.m_TextBuf.Clear(); + m_SAXContext.m_TextBuf.str(""); } -- cgit v1.2.3