diff options
author | Lei Zhang <thestig@chromium.org> | 2018-08-13 19:08:58 +0000 |
---|---|---|
committer | Chromium commit bot <commit-bot@chromium.org> | 2018-08-13 19:08:58 +0000 |
commit | b850c987d141c5578535faba64d14782dbfc13da (patch) | |
tree | 25df85e49d3076c59969a2c758e6781b1db6bae2 /fpdfsdk | |
parent | 5503fe3a9200f966ebc33c808476316e64e6b82b (diff) | |
download | pdfium-b850c987d141c5578535faba64d14782dbfc13da.tar.xz |
Move CPDFSDK_MemoryAccess to fxcrt.
Rename it CFX_ReadOnlyMemoryStream and swap out one use of CFX_MemoryStream.
BUG=pdfium:263
Change-Id: I15012df156a6a4d7c36f6fd58f32c355eae5fa1a
Reviewed-on: https://pdfium-review.googlesource.com/39878
Reviewed-by: Tom Sepez <tsepez@chromium.org>
Commit-Queue: Lei Zhang <thestig@chromium.org>
Diffstat (limited to 'fpdfsdk')
-rw-r--r-- | fpdfsdk/cpdfsdk_memoryaccess.cpp | 32 | ||||
-rw-r--r-- | fpdfsdk/cpdfsdk_memoryaccess.h | 29 | ||||
-rw-r--r-- | fpdfsdk/fpdf_view.cpp | 4 |
3 files changed, 2 insertions, 63 deletions
diff --git a/fpdfsdk/cpdfsdk_memoryaccess.cpp b/fpdfsdk/cpdfsdk_memoryaccess.cpp deleted file mode 100644 index 2a5b7aed00..0000000000 --- a/fpdfsdk/cpdfsdk_memoryaccess.cpp +++ /dev/null @@ -1,32 +0,0 @@ -// Copyright 2018 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 "fpdfsdk/cpdfsdk_memoryaccess.h" - -CPDFSDK_MemoryAccess::CPDFSDK_MemoryAccess(const uint8_t* pBuf, - FX_FILESIZE size) - : m_pBuf(pBuf), m_size(size) {} - -CPDFSDK_MemoryAccess::~CPDFSDK_MemoryAccess() = default; - -FX_FILESIZE CPDFSDK_MemoryAccess::GetSize() { - return m_size; -} - -bool CPDFSDK_MemoryAccess::ReadBlock(void* buffer, - FX_FILESIZE offset, - size_t size) { - if (offset < 0) - return false; - - FX_SAFE_FILESIZE newPos = pdfium::base::checked_cast<FX_FILESIZE>(size); - newPos += offset; - if (!newPos.IsValid() || newPos.ValueOrDie() > m_size) - return false; - - memcpy(buffer, m_pBuf + offset, size); - return true; -} diff --git a/fpdfsdk/cpdfsdk_memoryaccess.h b/fpdfsdk/cpdfsdk_memoryaccess.h deleted file mode 100644 index ed9c80acb5..0000000000 --- a/fpdfsdk/cpdfsdk_memoryaccess.h +++ /dev/null @@ -1,29 +0,0 @@ -// Copyright 2018 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 - -#ifndef FPDFSDK_CPDFSDK_MEMORYACCESS_H_ -#define FPDFSDK_CPDFSDK_MEMORYACCESS_H_ - -#include "core/fxcrt/fx_stream.h" - -class CPDFSDK_MemoryAccess final : public IFX_SeekableReadStream { - public: - template <typename T, typename... Args> - friend RetainPtr<T> pdfium::MakeRetain(Args&&... args); - - // IFX_SeekableReadStream: - FX_FILESIZE GetSize() override; - bool ReadBlock(void* buffer, FX_FILESIZE offset, size_t size) override; - - private: - CPDFSDK_MemoryAccess(const uint8_t* pBuf, FX_FILESIZE size); - ~CPDFSDK_MemoryAccess() override; - - const uint8_t* const m_pBuf; - const FX_FILESIZE m_size; -}; - -#endif // FPDFSDK_CPDFSDK_MEMORYACCESS_H_ diff --git a/fpdfsdk/fpdf_view.cpp b/fpdfsdk/fpdf_view.cpp index c44d582fd0..bd8cfe1e25 100644 --- a/fpdfsdk/fpdf_view.cpp +++ b/fpdfsdk/fpdf_view.cpp @@ -26,6 +26,7 @@ #include "core/fpdfdoc/cpdf_nametree.h" #include "core/fpdfdoc/cpdf_occontext.h" #include "core/fpdfdoc/cpdf_viewerpreferences.h" +#include "core/fxcrt/cfx_readonlymemorystream.h" #include "core/fxcrt/fx_stream.h" #include "core/fxcrt/fx_system.h" #include "core/fxcrt/unowned_ptr.h" @@ -35,7 +36,6 @@ #include "fpdfsdk/cpdfsdk_customaccess.h" #include "fpdfsdk/cpdfsdk_formfillenvironment.h" #include "fpdfsdk/cpdfsdk_helpers.h" -#include "fpdfsdk/cpdfsdk_memoryaccess.h" #include "fpdfsdk/cpdfsdk_pageview.h" #include "fpdfsdk/ipdfsdk_pauseadapter.h" #include "fxjs/ijs_runtime.h" @@ -269,7 +269,7 @@ FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FPDF_LoadXFA(FPDF_DOCUMENT document) { FPDF_EXPORT FPDF_DOCUMENT FPDF_CALLCONV FPDF_LoadMemDocument(const void* data_buf, int size, FPDF_BYTESTRING password) { - return LoadDocumentImpl(pdfium::MakeRetain<CPDFSDK_MemoryAccess>( + return LoadDocumentImpl(pdfium::MakeRetain<CFX_ReadOnlyMemoryStream>( static_cast<const uint8_t*>(data_buf), size), password); } |