From b38a900497ab85c5badd5f1cd1f8c00d0c6f580d Mon Sep 17 00:00:00 2001 From: Tom Sepez Date: Fri, 30 Jan 2015 14:31:58 -0800 Subject: Track formhandles in EmbedderTest class itself This removes some duplicated code from each individual test. R=thestig@chromium.org Review URL: https://codereview.chromium.org/885403002 --- testing/embedder_test.cpp | 48 ++++++++++++++++++++++------------------------- testing/embedder_test.h | 21 +++++++++------------ 2 files changed, 31 insertions(+), 38 deletions(-) (limited to 'testing') diff --git a/testing/embedder_test.cpp b/testing/embedder_test.cpp index 88cce00f5a..6cbfbf5191 100644 --- a/testing/embedder_test.cpp +++ b/testing/embedder_test.cpp @@ -190,7 +190,13 @@ void EmbedderTest::SetUp() { } void EmbedderTest::TearDown() { - FPDF_CloseDocument(document_); + if (form_handle_) { + FORM_DoDocumentAAction(form_handle_, FPDFDOC_AACTION_WC); + FPDFDOC_ExitFormFillEnvironment(form_handle_); + } + if (document_) { + FPDF_CloseDocument(document_); + } FPDFAvail_Destroy(avail_); FPDF_DestroyLibrary(); if (loader_) { @@ -229,10 +235,7 @@ bool EmbedderTest::OpenDocument(const std::string& filename) { (void) FPDF_GetDocPermissions(document_); (void) FPDFAvail_IsFormAvail(avail_, &hints_); - return true; -} -FPDF_FORMHANDLE EmbedderTest::SetFormFillEnvironment() { IPDF_JSPLATFORM platform_callbacks; memset(&platform_callbacks, '\0', sizeof(platform_callbacks)); platform_callbacks.version = 1; @@ -243,21 +246,16 @@ FPDF_FORMHANDLE EmbedderTest::SetFormFillEnvironment() { form_callbacks.version = 1; form_callbacks.m_pJsPlatform = &platform_callbacks; - FPDF_FORMHANDLE form = FPDFDOC_InitFormFillEnvironment(document_, - &form_callbacks); - FPDF_SetFormFieldHighlightColor(form, 0, 0xFFE4DD); - FPDF_SetFormFieldHighlightAlpha(form, 100); - return form; -} + form_handle_ = FPDFDOC_InitFormFillEnvironment(document_, &form_callbacks); + FPDF_SetFormFieldHighlightColor(form_handle_, 0, 0xFFE4DD); + FPDF_SetFormFieldHighlightAlpha(form_handle_, 100); -void EmbedderTest::ClearFormFillEnvironment(FPDF_FORMHANDLE form) { - FORM_DoDocumentAAction(form, FPDFDOC_AACTION_WC); - FPDFDOC_ExitFormFillEnvironment(form); + return true; } -void EmbedderTest::DoOpenActions(FPDF_FORMHANDLE form) { - FORM_DoDocumentJSAction(form); - FORM_DoDocumentOpenAction(form); +void EmbedderTest::DoOpenActions() { + FORM_DoDocumentJSAction(form_handle_); + FORM_DoDocumentOpenAction(form_handle_); } int EmbedderTest::GetFirstPageNum() { @@ -274,31 +272,29 @@ int EmbedderTest::GetPageCount() { return page_count; } -FPDF_PAGE EmbedderTest::LoadPage(int page_number, - FPDF_FORMHANDLE form) { +FPDF_PAGE EmbedderTest::LoadPage(int page_number) { FPDF_PAGE page = FPDF_LoadPage(document_, page_number); if (!page) { return nullptr; } - FORM_OnAfterLoadPage(page, form); - FORM_DoPageAAction(page, form, FPDFPAGE_AACTION_OPEN); + FORM_OnAfterLoadPage(page, form_handle_); + FORM_DoPageAAction(page, form_handle_, FPDFPAGE_AACTION_OPEN); return page; } -FPDF_BITMAP EmbedderTest::RenderPage(FPDF_PAGE page, - FPDF_FORMHANDLE form) { +FPDF_BITMAP EmbedderTest::RenderPage(FPDF_PAGE page) { int width = static_cast(FPDF_GetPageWidth(page)); int height = static_cast(FPDF_GetPageHeight(page)); FPDF_BITMAP bitmap = FPDFBitmap_Create(width, height, 0); FPDFBitmap_FillRect(bitmap, 0, 0, width, height, 0xFFFFFFFF); FPDF_RenderPageBitmap(bitmap, page, 0, 0, width, height, 0, 0); - FPDF_FFLDraw(form, bitmap, page, 0, 0, width, height, 0, 0); + FPDF_FFLDraw(form_handle_, bitmap, page, 0, 0, width, height, 0, 0); return bitmap; } -void EmbedderTest::UnloadPage(FPDF_PAGE page, FPDF_FORMHANDLE form) { - FORM_DoPageAAction(page, form, FPDFPAGE_AACTION_CLOSE); - FORM_OnBeforeClosePage(page, form); +void EmbedderTest::UnloadPage(FPDF_PAGE page) { + FORM_DoPageAAction(page, form_handle_, FPDFPAGE_AACTION_CLOSE); + FORM_OnBeforeClosePage(page, form_handle_); FPDF_ClosePage(page); } diff --git a/testing/embedder_test.h b/testing/embedder_test.h index 3eb3be606f..072dce3bc3 100644 --- a/testing/embedder_test.h +++ b/testing/embedder_test.h @@ -22,6 +22,7 @@ class EmbedderTest : public ::testing::Test { public: EmbedderTest() : document_(nullptr), + form_handle_(nullptr), avail_(nullptr), loader_(nullptr), file_length_(0), @@ -37,36 +38,32 @@ class EmbedderTest : public ::testing::Test { void TearDown() override; FPDF_DOCUMENT document() { return document_; } + FPDF_FORMHANDLE form_handle() { return form_handle_; } - // Open the document specified by |filename|, or return false on failure. + // Open the document specified by |filename|, and create its form fill + // environment, or return false on failure. virtual bool OpenDocument(const std::string& filename); - // Create and return a handle to the form fill module for use with the - // FORM_ family of functions from fpdfformfill.h, or return NULL on failure. - virtual FPDF_FORMHANDLE SetFormFillEnvironment(); - - // Release the resources obtained from SetFormFillEnvironment(). - virtual void ClearFormFillEnvironment(FPDF_FORMHANDLE form); - // Perform JavaScript actions that are to run at document open time. - virtual void DoOpenActions(FPDF_FORMHANDLE form); + virtual void DoOpenActions(); // Determine the page numbers present in the document. virtual int GetFirstPageNum(); virtual int GetPageCount(); // Load a specific page of the open document. - virtual FPDF_PAGE LoadPage(int page_number, FPDF_FORMHANDLE form); + virtual FPDF_PAGE LoadPage(int page_number); // Convert a loaded page into a bitmap. - virtual FPDF_BITMAP RenderPage(FPDF_PAGE page, FPDF_FORMHANDLE form); + virtual FPDF_BITMAP RenderPage(FPDF_PAGE page); // Relese the resources obtained from LoadPage(). Further use of |page| // is prohibited after this call is made. - virtual void UnloadPage(FPDF_PAGE page, FPDF_FORMHANDLE form); + virtual void UnloadPage(FPDF_PAGE page); protected: FPDF_DOCUMENT document_; + FPDF_FORMHANDLE form_handle_; FPDF_AVAIL avail_; FX_DOWNLOADHINTS hints_; FPDF_FILEACCESS file_access_; -- cgit v1.2.3