From f78bf1a54a4afb6486869b4bc5850283225d7055 Mon Sep 17 00:00:00 2001 From: tsepez Date: Thu, 1 Dec 2016 15:16:54 -0800 Subject: Make concrete stream classes private to .cpp, part 3 Review-Url: https://codereview.chromium.org/2545953002 --- xfa/fxfa/app/xfa_ffapp.cpp | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'xfa/fxfa/app/xfa_ffapp.cpp') diff --git a/xfa/fxfa/app/xfa_ffapp.cpp b/xfa/fxfa/app/xfa_ffapp.cpp index 797c3e72f0..9c0411b731 100644 --- a/xfa/fxfa/app/xfa_ffapp.cpp +++ b/xfa/fxfa/app/xfa_ffapp.cpp @@ -21,6 +21,22 @@ #include "xfa/fxfa/xfa_ffwidgethandler.h" #include "xfa/fxfa/xfa_fontmgr.h" +namespace { + +class CXFA_FileRead : public IFX_SeekableReadStream { + public: + explicit CXFA_FileRead(const std::vector& streams); + ~CXFA_FileRead() override; + + // IFX_SeekableReadStream + FX_FILESIZE GetSize() override; + bool ReadBlock(void* buffer, FX_FILESIZE offset, size_t size) override; + void Release() override; + + private: + CFX_ObjectArray m_Data; +}; + CXFA_FileRead::CXFA_FileRead(const std::vector& streams) { for (CPDF_Stream* pStream : streams) { CPDF_StreamAcc& acc = m_Data.Add(); @@ -72,6 +88,13 @@ void CXFA_FileRead::Release() { delete this; } +} // namespace + +IFX_SeekableReadStream* MakeSeekableReadStream( + const std::vector& streams) { + return new CXFA_FileRead(streams); +} + CXFA_FFApp::CXFA_FFApp(IXFA_AppProvider* pProvider) : m_pProvider(pProvider), m_pWidgetMgrDelegate(nullptr), -- cgit v1.2.3