|  | // Copyright 2018 The PDFium Authors | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef CORE_FPDFAPI_EDIT_CPDF_PAGECONTENTMANAGER_H_ | 
|  | #define CORE_FPDFAPI_EDIT_CPDF_PAGECONTENTMANAGER_H_ | 
|  |  | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include <set> | 
|  | #include <variant> | 
|  |  | 
|  | #include "core/fxcrt/fx_string_wrappers.h" | 
|  | #include "core/fxcrt/retain_ptr.h" | 
|  | #include "core/fxcrt/unowned_ptr.h" | 
|  |  | 
|  | class CPDF_Array; | 
|  | class CPDF_Document; | 
|  | class CPDF_PageObjectHolder; | 
|  | class CPDF_Stream; | 
|  |  | 
|  | class CPDF_PageContentManager { | 
|  | public: | 
|  | CPDF_PageContentManager(CPDF_PageObjectHolder* page_obj_holder, | 
|  | CPDF_Document* document); | 
|  | ~CPDF_PageContentManager(); | 
|  |  | 
|  | // Adds a new Content stream. Its index in the array will be returned, or 0 | 
|  | // if Contents is not an array, but only a single stream. | 
|  | size_t AddStream(fxcrt::ostringstream* buf); | 
|  |  | 
|  | // Changes the stream at `stream_index` to contain the data in `buf`. If `buf` | 
|  | // is empty, then schedule the removal of the stream instead. | 
|  | void UpdateStream(size_t stream_index, fxcrt::ostringstream* buf); | 
|  |  | 
|  | bool HasStreamAtIndex(size_t stream_index); | 
|  |  | 
|  | private: | 
|  | // Gets the Content stream at a given index. If Contents is a single stream | 
|  | // rather than an array, it is retrievable at index 0. | 
|  | RetainPtr<CPDF_Stream> GetStreamByIndex(size_t stream_index); | 
|  |  | 
|  | // Schedules the removal of the Content stream at a given index. It will be | 
|  | // removed upon CPDF_PageContentManager destruction. | 
|  | void ScheduleRemoveStreamByIndex(size_t stream_index); | 
|  |  | 
|  | // Removes all Content streams for which ScheduleRemoveStreamByIndex() was | 
|  | // called. Update the content stream of all page objects with the shifted | 
|  | // indexes. | 
|  | void ExecuteScheduledRemovals(); | 
|  |  | 
|  | RetainPtr<CPDF_Stream> GetContentsStream(); | 
|  | RetainPtr<CPDF_Array> GetContentsArray(); | 
|  |  | 
|  | UnownedPtr<CPDF_PageObjectHolder> const page_obj_holder_; | 
|  | UnownedPtr<CPDF_Document> const document_; | 
|  | const std::set<uint32_t> objects_with_multi_refs_; | 
|  | // When holding a CPDF_Stream, the pointer may be null. | 
|  | std::variant<RetainPtr<CPDF_Stream>, RetainPtr<CPDF_Array>> contents_; | 
|  | std::set<size_t> streams_to_remove_; | 
|  | }; | 
|  |  | 
|  | #endif  // CORE_FPDFAPI_EDIT_CPDF_PAGECONTENTMANAGER_H_ |