Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1557)

Unified Diff: core/fpdfapi/fpdf_page/cpdf_imageobject.cpp

Issue 2194393002: Fix a leak with FPDFPageObj_NewImgeObj(). (Closed) Base URL: https://pdfium.googlesource.com/pdfium@master
Patch Set: Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « core/fpdfapi/fpdf_page/cpdf_image.cpp ('k') | core/fpdfapi/fpdf_page/fpdf_page_doc.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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..929f162725c8e068bf2d0b3606d85827cc847389 100644
--- a/core/fpdfapi/fpdf_page/cpdf_imageobject.cpp
+++ b/core/fpdfapi/fpdf_page/cpdf_imageobject.cpp
@@ -13,15 +13,19 @@
CPDF_ImageObject::CPDF_ImageObject() : m_pImage(nullptr) {}
CPDF_ImageObject::~CPDF_ImageObject() {
- if (!m_pImage) {
+ if (!m_pImage)
+ return;
+
+ if (m_pImage->CanRelease()) {
+ m_pImage->Release();
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());
- }
+
+ auto* pPageData = m_pImage->GetDocument()->GetPageData();
+ if (pPageData->ReleaseImage(m_pImage->GetStream()))
+ return;
+
+ delete m_pImage;
Lei Zhang 2016/08/01 22:08:03 Not sure what else we can do here.
Wei Li 2016/08/04 18:00:39 I suspect this might not be the right thing to do.
Lei Zhang 2016/08/04 21:58:25 Does you comment apply to patch set 2 as well?
Wei Li 2016/08/04 23:36:39 Yes, I think both patches share similar logic. Cou
Lei Zhang 2016/08/05 18:55:22 So CPDF_ImageObject::m_pImage gets assigned from 6
}
CPDF_ImageObject* CPDF_ImageObject::Clone() const {
« no previous file with comments | « core/fpdfapi/fpdf_page/cpdf_image.cpp ('k') | core/fpdfapi/fpdf_page/fpdf_page_doc.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698