diff options
author | Lei Zhang <thestig@chromium.org> | 2018-05-09 21:28:32 +0000 |
---|---|---|
committer | Chromium commit bot <commit-bot@chromium.org> | 2018-05-09 21:28:32 +0000 |
commit | 81981300c2892598784f8b7096d5143ac04293a7 (patch) | |
tree | 3ed5b42c0aaec60d63f90dab8f1d7f93c3366f15 /core/fpdfapi/edit/cpdf_flateencoder.cpp | |
parent | 607f3cd63a314cd3a6c219b19cce31805b66cd6d (diff) | |
download | pdfium-81981300c2892598784f8b7096d5143ac04293a7.tar.xz |
Split the MaybeOwned CPDF_Dictionary in CPDF_FlateEncoder.
The owned copy needs to be modified, so it should be non-const. Whereas
the unowned copy can be const.
Add a GetClonedDict() method for accessing the modifiable dictionary.
Change-Id: Ia7f6bcc5f917864cd1bbc7b5000a86f6e433ae9a
Reviewed-on: https://pdfium-review.googlesource.com/32181
Reviewed-by: Henrique Nakashima <hnakashima@chromium.org>
Commit-Queue: Lei Zhang <thestig@chromium.org>
Diffstat (limited to 'core/fpdfapi/edit/cpdf_flateencoder.cpp')
-rw-r--r-- | core/fpdfapi/edit/cpdf_flateencoder.cpp | 38 |
1 files changed, 29 insertions, 9 deletions
diff --git a/core/fpdfapi/edit/cpdf_flateencoder.cpp b/core/fpdfapi/edit/cpdf_flateencoder.cpp index f6125b8847..a290da6dac 100644 --- a/core/fpdfapi/edit/cpdf_flateencoder.cpp +++ b/core/fpdfapi/edit/cpdf_flateencoder.cpp @@ -25,14 +25,16 @@ CPDF_FlateEncoder::CPDF_FlateEncoder(const CPDF_Stream* pStream, m_dwSize = pDestAcc->GetSize(); m_pData = pDestAcc->DetachData(); - m_pDict = ToDictionary(pStream->GetDict()->Clone()); - m_pDict->RemoveFor("Filter"); + m_pClonedDict = ToDictionary(pStream->GetDict()->Clone()); + m_pClonedDict->RemoveFor("Filter"); + ASSERT(!m_pDict); return; } if (bHasFilter || !bFlateEncode) { m_pData = m_pAcc->GetData(); m_dwSize = m_pAcc->GetSize(); m_pDict = pStream->GetDict(); + ASSERT(!m_pClonedDict); return; } @@ -41,18 +43,36 @@ CPDF_FlateEncoder::CPDF_FlateEncoder(const CPDF_Stream* pStream, ::FlateEncode(m_pAcc->GetData(), m_pAcc->GetSize(), &buffer, &m_dwSize); m_pData = std::unique_ptr<uint8_t, FxFreeDeleter>(buffer); - m_pDict = ToDictionary(pStream->GetDict()->Clone()); - m_pDict->SetNewFor<CPDF_Number>("Length", static_cast<int>(m_dwSize)); - m_pDict->SetNewFor<CPDF_Name>("Filter", "FlateDecode"); - m_pDict->RemoveFor(pdfium::stream::kDecodeParms); + m_pClonedDict = ToDictionary(pStream->GetDict()->Clone()); + m_pClonedDict->SetNewFor<CPDF_Number>("Length", static_cast<int>(m_dwSize)); + m_pClonedDict->SetNewFor<CPDF_Name>("Filter", "FlateDecode"); + m_pClonedDict->RemoveFor(pdfium::stream::kDecodeParms); + ASSERT(!m_pDict); } CPDF_FlateEncoder::~CPDF_FlateEncoder() {} void CPDF_FlateEncoder::CloneDict() { - if (m_pDict.IsOwned()) + if (m_pClonedDict) { + ASSERT(!m_pDict); return; + } + + m_pClonedDict = ToDictionary(m_pDict->Clone()); + ASSERT(m_pClonedDict); + m_pDict.Release(); +} + +CPDF_Dictionary* CPDF_FlateEncoder::GetClonedDict() { + ASSERT(!m_pDict); + return m_pClonedDict.get(); +} + +const CPDF_Dictionary* CPDF_FlateEncoder::GetDict() const { + if (m_pClonedDict) { + ASSERT(!m_pDict); + return m_pClonedDict.get(); + } - m_pDict = ToDictionary(m_pDict->Clone()); - ASSERT(m_pDict.IsOwned()); + return m_pDict.Get(); } |