Chromium Code Reviews| Index: core/fpdfapi/fpdf_page/cpdf_imageobject.cpp |
| diff --git a/core/fpdfapi/fpdf_page/cpdf_imageobject.cpp b/core/fpdfapi/fpdf_page/cpdf_imageobject.cpp |
| index e2defa80544be13b50a30babfe498ed7edae4a4e..cce9443149179b8cb91da8a5e76c03fe7136b128 100644 |
| --- a/core/fpdfapi/fpdf_page/cpdf_imageobject.cpp |
| +++ b/core/fpdfapi/fpdf_page/cpdf_imageobject.cpp |
| @@ -6,22 +6,17 @@ |
| #include "core/fpdfapi/fpdf_page/include/cpdf_imageobject.h" |
| +#include <memory> |
| + |
| #include "core/fpdfapi/fpdf_page/include/cpdf_image.h" |
| #include "core/fpdfapi/fpdf_page/pageint.h" |
| #include "core/fpdfapi/fpdf_parser/include/cpdf_document.h" |
| -CPDF_ImageObject::CPDF_ImageObject() : m_pImage(nullptr) {} |
| +CPDF_ImageObject::CPDF_ImageObject() |
| + : m_pImage(nullptr), m_pImageOwned(false) {} |
| CPDF_ImageObject::~CPDF_ImageObject() { |
| - if (!m_pImage) { |
| - return; |
| - } |
| - if (m_pImage->IsInline() || |
| - (m_pImage->GetStream() && m_pImage->GetStream()->GetObjNum() == 0)) { |
| - delete m_pImage; |
| - } else { |
| - m_pImage->GetDocument()->GetPageData()->ReleaseImage(m_pImage->GetStream()); |
| - } |
| + Release(); |
| } |
| CPDF_ImageObject* CPDF_ImageObject::Clone() const { |
| @@ -59,3 +54,32 @@ void CPDF_ImageObject::CalcBoundingBox() { |
| m_Right = m_Top = 1.0f; |
| m_Matrix.TransformRect(m_Left, m_Right, m_Top, m_Bottom); |
| } |
| + |
| +void CPDF_ImageObject::SetOwnedImage(std::unique_ptr<CPDF_Image> pImage) { |
| + Release(); |
| + m_pImage = pImage.release(); |
|
Wei Li
2016/08/09 22:22:07
std::move?
Lei Zhang
2016/08/09 22:28:52
Can't. |m_pImage| is a raw pointer, because it can
|
| + m_pImageOwned = true; |
| +} |
| + |
| +void CPDF_ImageObject::SetUnownedImage(CPDF_Image* pImage) { |
| + Release(); |
| + m_pImage = pImage; |
| + m_pImageOwned = false; |
| +} |
| + |
| +void CPDF_ImageObject::Release() { |
| + if (m_pImageOwned) { |
| + delete m_pImage; |
| + m_pImage = nullptr; |
| + m_pImageOwned = false; |
| + return; |
| + } |
| + |
| + if (!m_pImage) |
| + return; |
| + |
| + CPDF_DocPageData* pPageData = m_pImage->GetDocument()->GetPageData(); |
| + const CPDF_Object* pImageStream = m_pImage->GetStream(); |
|
Wei Li
2016/08/09 22:22:07
Nit: no need for |pImageStream|
Lei Zhang
2016/08/09 22:28:52
Done.
|
| + pPageData->ReleaseImage(pImageStream); |
| + m_pImage = nullptr; |
| +} |