From 05dcbc931eacb72f1a11835ae282fc8434b7a434 Mon Sep 17 00:00:00 2001 From: Lei Zhang Date: Fri, 22 Dec 2017 00:30:04 -0800 Subject: Only set CPDF_ColorSpace component count on successful load. Make sure all CPDF_ColorSpace instances consistently call v_Load(). Change-Id: I15c1608c36781a03131884abceff1ecc4a9a1eb1 Reviewed-on: https://pdfium-review.googlesource.com/21911 Reviewed-by: Henrique Nakashima Commit-Queue: Lei Zhang --- core/fpdfapi/page/cpdf_patterncs.cpp | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) (limited to 'core/fpdfapi/page/cpdf_patterncs.cpp') diff --git a/core/fpdfapi/page/cpdf_patterncs.cpp b/core/fpdfapi/page/cpdf_patterncs.cpp index d14a2c1976..b4b680f026 100644 --- a/core/fpdfapi/page/cpdf_patterncs.cpp +++ b/core/fpdfapi/page/cpdf_patterncs.cpp @@ -11,7 +11,7 @@ #include "core/fpdfapi/parser/cpdf_document.h" CPDF_PatternCS::CPDF_PatternCS(CPDF_Document* pDoc) - : CPDF_ColorSpace(pDoc, PDFCS_PATTERN, 1), + : CPDF_ColorSpace(pDoc, PDFCS_PATTERN), m_pBaseCS(nullptr), m_pCountedBaseCS(nullptr) {} @@ -24,32 +24,36 @@ CPDF_PatternCS::~CPDF_PatternCS() { } } -bool CPDF_PatternCS::v_Load(CPDF_Document* pDoc, - CPDF_Array* pArray, - std::set* pVisited) { +void CPDF_PatternCS::InitializeStockPattern() { + SetComponentsForStockCS(1); +} + +uint32_t CPDF_PatternCS::v_Load(CPDF_Document* pDoc, + CPDF_Array* pArray, + std::set* pVisited) { CPDF_Object* pBaseCS = pArray->GetDirectObjectAt(1); if (pBaseCS == m_pArray) - return false; + return 0; CPDF_DocPageData* pDocPageData = pDoc->GetPageData(); m_pBaseCS = pDocPageData->GetColorSpaceGuarded(pBaseCS, nullptr, pVisited); - if (!m_pBaseCS) { - m_nComponents = 1; - return true; - } + if (!m_pBaseCS) + return 1; if (m_pBaseCS->GetFamily() == PDFCS_PATTERN) - return false; + return 0; m_pCountedBaseCS = pDocPageData->FindColorSpacePtr(m_pBaseCS->GetArray()); - m_nComponents = m_pBaseCS->CountComponents() + 1; - return m_pBaseCS->CountComponents() <= kMaxPatternColorComps; + if (m_pBaseCS->CountComponents() > kMaxPatternColorComps) + return 0; + + return m_pBaseCS->CountComponents() + 1; } bool CPDF_PatternCS::GetRGB(float* pBuf, float* R, float* G, float* B) const { if (m_pBaseCS) { ASSERT(m_pBaseCS->GetFamily() != PDFCS_PATTERN); - PatternValue* pvalue = (PatternValue*)pBuf; + PatternValue* pvalue = reinterpret_cast(pBuf); if (m_pBaseCS->GetRGB(pvalue->m_Comps, R, G, B)) return true; } -- cgit v1.2.3