Chromium Code Reviews| Index: core/fpdfapi/fpdf_parser/include/cpdf_indirect_object_holder.h |
| diff --git a/core/fpdfapi/fpdf_parser/include/cpdf_indirect_object_holder.h b/core/fpdfapi/fpdf_parser/include/cpdf_indirect_object_holder.h |
| index c29746fdd79d8d4554713686fc00e69d0ed61a13..ba555a39ff6befcad10ec77dcbbb4e4980b67402 100644 |
| --- a/core/fpdfapi/fpdf_parser/include/cpdf_indirect_object_holder.h |
| +++ b/core/fpdfapi/fpdf_parser/include/cpdf_indirect_object_holder.h |
| @@ -19,24 +19,29 @@ class CPDF_IndirectObjectHolder { |
| using iterator = std::map<uint32_t, CPDF_Object*>::iterator; |
| using const_iterator = std::map<uint32_t, CPDF_Object*>::const_iterator; |
| - explicit CPDF_IndirectObjectHolder(CPDF_Parser* pParser); |
| - ~CPDF_IndirectObjectHolder(); |
| + CPDF_IndirectObjectHolder(); |
| + virtual ~CPDF_IndirectObjectHolder(); |
| + |
| + CPDF_Object* GetIndirectObject(uint32_t objnum) const; |
| + virtual CPDF_Object* GetIndirectObjectIfValid(uint32_t objnum); |
|
Tom Sepez
2016/08/17 16:46:45
Does this need to be virtual? Can it be const?
dsinclair
2016/08/17 16:59:25
It does need to be virtual as we have to override
Tom Sepez
2016/08/17 17:15:31
Alternatively, we could have a virtual ParseIndire
dsinclair
2016/08/17 18:16:44
Done.
|
| - CPDF_Object* GetIndirectObject(uint32_t objnum); |
| - uint32_t AddIndirectObject(CPDF_Object* pObj); |
| void ReleaseIndirectObject(uint32_t objnum); |
| - // Takes ownership of |pObj|. |
| - bool InsertIndirectObject(uint32_t objnum, CPDF_Object* pObj); |
| + // The following take ownership of |pObj|. |
| + bool InsertIndirectObjectIfHigherGeneration(uint32_t objnum, |
| + CPDF_Object* pObj); |
| + uint32_t AddIndirectObject(CPDF_Object* pObj); |
| + void EmplaceIndirectObject(CPDF_Object* pObj); |
| uint32_t GetLastObjNum() const { return m_LastObjNum; } |
| + void SetLastObjNum(uint32_t objnum) { m_LastObjNum = objnum; } |
| + |
| iterator begin() { return m_IndirectObjs.begin(); } |
| const_iterator begin() const { return m_IndirectObjs.begin(); } |
| iterator end() { return m_IndirectObjs.end(); } |
| const_iterator end() const { return m_IndirectObjs.end(); } |
| - protected: |
| - CPDF_Parser* m_pParser; |
| + private: |
| uint32_t m_LastObjNum; |
| std::map<uint32_t, CPDF_Object*> m_IndirectObjs; |
| }; |