From ccf206a7731e0df773a4c5941736953446ec4d9d Mon Sep 17 00:00:00 2001 From: Ryan Harrison Date: Tue, 14 Nov 2017 16:05:53 +0000 Subject: Move CXFA_FileRead out of XFA and rename This code doesn't depend on XFA, but is only used by it. Moving it out, so it will be easier for me to write some tools for extracting data out of PDFs. Bug: Change-Id: Ic18613b46abed5124c47f539833b01b12c1c6e56 Reviewed-on: https://pdfium-review.googlesource.com/18410 Reviewed-by: dsinclair Commit-Queue: Ryan Harrison --- core/fxcrt/cfx_seekablemultistream.cpp | 85 ++++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 core/fxcrt/cfx_seekablemultistream.cpp (limited to 'core/fxcrt/cfx_seekablemultistream.cpp') diff --git a/core/fxcrt/cfx_seekablemultistream.cpp b/core/fxcrt/cfx_seekablemultistream.cpp new file mode 100644 index 0000000000..12682d7678 --- /dev/null +++ b/core/fxcrt/cfx_seekablemultistream.cpp @@ -0,0 +1,85 @@ +// 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. + +// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com + +#include "core/fxcrt/cfx_seekablemultistream.h" + +#include + +#include "core/fpdfapi/parser/cpdf_stream_acc.h" +#include "third_party/base/logging.h" +#include "third_party/base/stl_util.h" + +CFX_SeekableMultiStream::CFX_SeekableMultiStream( + const std::vector& streams) { + for (CPDF_Stream* pStream : streams) { + m_Data.push_back(pdfium::MakeRetain(pStream)); + m_Data.back()->LoadAllData(); + } +} + +CFX_SeekableMultiStream::~CFX_SeekableMultiStream() {} + +FX_FILESIZE CFX_SeekableMultiStream::GetSize() { + uint32_t dwSize = 0; + for (const auto& acc : m_Data) + dwSize += acc->GetSize(); + return dwSize; +} + +bool CFX_SeekableMultiStream::ReadBlock(void* buffer, + FX_FILESIZE offset, + size_t size) { + int32_t iCount = pdfium::CollectionSize(m_Data); + int32_t index = 0; + while (index < iCount) { + const auto& acc = m_Data[index]; + FX_FILESIZE dwSize = acc->GetSize(); + if (offset < dwSize) + break; + + offset -= dwSize; + index++; + } + while (index < iCount) { + const auto& acc = m_Data[index]; + uint32_t dwSize = acc->GetSize(); + size_t dwRead = std::min(size, static_cast(dwSize - offset)); + memcpy(buffer, acc->GetData() + offset, dwRead); + size -= dwRead; + if (size == 0) + return true; + + buffer = static_cast(buffer) + dwRead; + offset = 0; + index++; + } + return false; +} + +size_t CFX_SeekableMultiStream::ReadBlock(void* buffer, size_t size) { + NOTREACHED(); + return 0; +} + +FX_FILESIZE CFX_SeekableMultiStream::GetPosition() { + return 0; +} + +bool CFX_SeekableMultiStream::IsEOF() { + return false; +} + +bool CFX_SeekableMultiStream::Flush() { + NOTREACHED(); + return false; +} + +bool CFX_SeekableMultiStream::WriteBlock(const void* pData, + FX_FILESIZE offset, + size_t size) { + NOTREACHED(); + return false; +} -- cgit v1.2.3