| Index: core/fpdfapi/parser/cpdf_document_unittest.cpp
|
| diff --git a/core/fpdfapi/parser/cpdf_document_unittest.cpp b/core/fpdfapi/parser/cpdf_document_unittest.cpp
|
| index f27e7403f645b8b2c71f720ae07cc4bc119ad031..048a9fead20ebbeee93acf61ff71b156ac74481b 100644
|
| --- a/core/fpdfapi/parser/cpdf_document_unittest.cpp
|
| +++ b/core/fpdfapi/parser/cpdf_document_unittest.cpp
|
| @@ -13,24 +13,25 @@
|
| #include "core/fpdfapi/parser/cpdf_parser.h"
|
| #include "core/fxcrt/fx_memory.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
| +#include "third_party/base/ptr_util.h"
|
|
|
| namespace {
|
|
|
| -CPDF_Dictionary* CreatePageTreeNode(CPDF_Array* kids,
|
| +CPDF_Dictionary* CreatePageTreeNode(std::unique_ptr<CPDF_Array> kids,
|
| CPDF_Document* pDoc,
|
| int count) {
|
| - CPDF_Dictionary* pageNode = new CPDF_Dictionary();
|
| + CPDF_Array* pUnowned = pDoc->AddIndirectObject(std::move(kids))->AsArray();
|
| + CPDF_Dictionary* pageNode = pDoc->NewIndirect<CPDF_Dictionary>();
|
| pageNode->SetStringFor("Type", "Pages");
|
| - pageNode->SetReferenceFor("Kids", pDoc, pDoc->AddIndirectObject(kids));
|
| + pageNode->SetReferenceFor("Kids", pDoc, pUnowned);
|
| pageNode->SetIntegerFor("Count", count);
|
| - uint32_t pageNodeRef = pDoc->AddIndirectObject(pageNode);
|
| - for (size_t i = 0; i < kids->GetCount(); i++)
|
| - kids->GetDictAt(i)->SetReferenceFor("Parent", pDoc, pageNodeRef);
|
| + for (size_t i = 0; i < pUnowned->GetCount(); i++)
|
| + pUnowned->GetDictAt(i)->SetReferenceFor("Parent", pDoc, pageNode);
|
| return pageNode;
|
| }
|
|
|
| -CPDF_Dictionary* CreateNumberedPage(size_t number) {
|
| - CPDF_Dictionary* page = new CPDF_Dictionary();
|
| +std::unique_ptr<CPDF_Dictionary> CreateNumberedPage(size_t number) {
|
| + auto page = pdfium::MakeUnique<CPDF_Dictionary>();
|
| page->SetStringFor("Type", "Page");
|
| page->SetIntegerFor("PageNumbering", number);
|
| return page;
|
| @@ -40,34 +41,37 @@ class CPDF_TestDocumentForPages : public CPDF_Document {
|
| public:
|
| CPDF_TestDocumentForPages() : CPDF_Document(nullptr) {
|
| // Set up test
|
| - CPDF_Array* zeroToTwo = new CPDF_Array();
|
| + auto zeroToTwo = pdfium::MakeUnique<CPDF_Array>();
|
| zeroToTwo->AddReference(this, AddIndirectObject(CreateNumberedPage(0)));
|
| zeroToTwo->AddReference(this, AddIndirectObject(CreateNumberedPage(1)));
|
| zeroToTwo->AddReference(this, AddIndirectObject(CreateNumberedPage(2)));
|
| - CPDF_Dictionary* branch1 = CreatePageTreeNode(zeroToTwo, this, 3);
|
| + CPDF_Dictionary* branch1 =
|
| + CreatePageTreeNode(std::move(zeroToTwo), this, 3);
|
|
|
| - CPDF_Array* zeroToThree = new CPDF_Array();
|
| + auto zeroToThree = pdfium::MakeUnique<CPDF_Array>();
|
| zeroToThree->AddReference(this, branch1->GetObjNum());
|
| zeroToThree->AddReference(this, AddIndirectObject(CreateNumberedPage(3)));
|
| - CPDF_Dictionary* branch2 = CreatePageTreeNode(zeroToThree, this, 4);
|
| + CPDF_Dictionary* branch2 =
|
| + CreatePageTreeNode(std::move(zeroToThree), this, 4);
|
|
|
| - CPDF_Array* fourFive = new CPDF_Array();
|
| + auto fourFive = pdfium::MakeUnique<CPDF_Array>();
|
| fourFive->AddReference(this, AddIndirectObject(CreateNumberedPage(4)));
|
| fourFive->AddReference(this, AddIndirectObject(CreateNumberedPage(5)));
|
| - CPDF_Dictionary* branch3 = CreatePageTreeNode(fourFive, this, 2);
|
| + CPDF_Dictionary* branch3 = CreatePageTreeNode(std::move(fourFive), this, 2);
|
|
|
| - CPDF_Array* justSix = new CPDF_Array();
|
| + auto justSix = pdfium::MakeUnique<CPDF_Array>();
|
| justSix->AddReference(this, AddIndirectObject(CreateNumberedPage(6)));
|
| - CPDF_Dictionary* branch4 = CreatePageTreeNode(justSix, this, 1);
|
| + CPDF_Dictionary* branch4 = CreatePageTreeNode(std::move(justSix), this, 1);
|
|
|
| - CPDF_Array* allPages = new CPDF_Array();
|
| - allPages->AddReference(this, branch2->GetObjNum());
|
| - allPages->AddReference(this, branch3->GetObjNum());
|
| - allPages->AddReference(this, branch4->GetObjNum());
|
| - CPDF_Dictionary* pagesDict = CreatePageTreeNode(allPages, this, 7);
|
| + auto allPages = pdfium::MakeUnique<CPDF_Array>();
|
| + allPages->AddReference(this, branch2);
|
| + allPages->AddReference(this, branch3);
|
| + allPages->AddReference(this, branch4);
|
| + CPDF_Dictionary* pagesDict =
|
| + CreatePageTreeNode(std::move(allPages), this, 7);
|
|
|
| - m_pOwnedRootDict.reset(new CPDF_Dictionary());
|
| - m_pOwnedRootDict->SetReferenceFor("Pages", this, pagesDict->GetObjNum());
|
| + m_pOwnedRootDict = pdfium::MakeUnique<CPDF_Dictionary>();
|
| + m_pOwnedRootDict->SetReferenceFor("Pages", this, pagesDict);
|
| m_pRootDict = m_pOwnedRootDict.get();
|
| m_PageList.SetSize(7);
|
| }
|
| @@ -80,13 +84,13 @@ class CPDF_TestDocumentWithPageWithoutPageNum : public CPDF_Document {
|
| public:
|
| CPDF_TestDocumentWithPageWithoutPageNum() : CPDF_Document(nullptr) {
|
| // Set up test
|
| - CPDF_Array* allPages = new CPDF_Array();
|
| + auto allPages = pdfium::MakeUnique<CPDF_Array>();
|
| allPages->AddReference(this, AddIndirectObject(CreateNumberedPage(0)));
|
| allPages->AddReference(this, AddIndirectObject(CreateNumberedPage(1)));
|
| // Page without pageNum.
|
| - allPages->Add(CreateNumberedPage(2));
|
| - CPDF_Dictionary* pagesDict = CreatePageTreeNode(allPages, this, 3);
|
| -
|
| + allPages->Add(CreateNumberedPage(2).release());
|
| + CPDF_Dictionary* pagesDict =
|
| + CreatePageTreeNode(std::move(allPages), this, 3);
|
| m_pOwnedRootDict.reset(new CPDF_Dictionary());
|
| m_pOwnedRootDict->SetReferenceFor("Pages", this, pagesDict->GetObjNum());
|
| m_pRootDict = m_pOwnedRootDict.get();
|
| @@ -186,15 +190,14 @@ TEST_F(cpdf_document_test, UseCachedPageObjNumIfHaveNotPagesDict) {
|
| TestLinearized linearized(dict.get());
|
| document.LoadLinearizedDoc(&linearized);
|
| ASSERT_EQ(page_count, document.GetPageCount());
|
| - CPDF_Object* page_stub = new CPDF_Dictionary();
|
| - const uint32_t obj_num = document.AddIndirectObject(page_stub);
|
| + CPDF_Object* page_stub = document.NewIndirect<CPDF_Dictionary>();
|
| + const uint32_t obj_num = page_stub->GetObjNum();
|
| const int test_page_num = 33;
|
|
|
| EXPECT_FALSE(document.IsPageLoaded(test_page_num));
|
| EXPECT_EQ(nullptr, document.GetPage(test_page_num));
|
|
|
| document.SetPageObjNum(test_page_num, obj_num);
|
| -
|
| EXPECT_TRUE(document.IsPageLoaded(test_page_num));
|
| EXPECT_EQ(page_stub, document.GetPage(test_page_num));
|
| }
|
|
|