Index: fpdfsdk/fpdfformfill.cpp |
diff --git a/fpdfsdk/fpdfformfill.cpp b/fpdfsdk/fpdfformfill.cpp |
index 050a401f0275bc3a831bc31ac72491595e4a2153..184f7ca3416246b132976d8ef709202603b265d8 100644 |
--- a/fpdfsdk/fpdfformfill.cpp |
+++ b/fpdfsdk/fpdfformfill.cpp |
@@ -44,8 +44,10 @@ CPDFSDK_FormFillEnvironment* HandleToCPDFSDKEnvironment( |
} |
CPDFSDK_InterForm* FormHandleToInterForm(FPDF_FORMHANDLE hHandle) { |
- CPDFSDK_Document* pSDKDoc = CPDFSDK_Document::FromFPDFFormHandle(hHandle); |
- return pSDKDoc ? pSDKDoc->GetInterForm() : nullptr; |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ return pFormFillEnv ? pFormFillEnv->GetSDKDocument()->GetInterForm() |
+ : nullptr; |
} |
CPDFSDK_PageView* FormHandleToPageView(FPDF_FORMHANDLE hHandle, |
@@ -54,8 +56,10 @@ CPDFSDK_PageView* FormHandleToPageView(FPDF_FORMHANDLE hHandle, |
if (!pPage) |
return nullptr; |
- CPDFSDK_Document* pSDKDoc = CPDFSDK_Document::FromFPDFFormHandle(hHandle); |
- return pSDKDoc ? pSDKDoc->GetPageView(pPage, true) : nullptr; |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ return pFormFillEnv ? pFormFillEnv->GetSDKDocument()->GetPageView(pPage, true) |
+ : nullptr; |
} |
#ifdef PDF_ENABLE_XFA |
@@ -92,9 +96,9 @@ void FFLCommon(FPDF_FORMHANDLE hHandle, |
CPDF_Document* pPDFDoc = pDocument->GetPDFDoc(); |
if (!pPDFDoc) |
return; |
- CPDFSDK_FormFillEnvironment* pEnv = HandleToCPDFSDKEnvironment(hHandle); |
- CPDFSDK_Document* pFXDoc = pEnv->GetSDKDocument(); |
- if (!pFXDoc) |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ if (!pFormFillEnv) |
return; |
#endif // PDF_ENABLE_XFA |
@@ -128,7 +132,8 @@ void FFLCommon(FPDF_FORMHANDLE hHandle, |
#ifdef PDF_ENABLE_XFA |
options.m_pOCContext = new CPDF_OCContext(pPDFDoc, CPDF_OCContext::View); |
- if (CPDFSDK_PageView* pPageView = pFXDoc->GetPageView(pPage, true)) |
+ if (CPDFSDK_PageView* pPageView = |
+ pFormFillEnv->GetSDKDocument()->GetPageView(pPage, true)) |
pPageView->PageView_OnDraw(pDevice.get(), &matrix, &options, clip); |
#else // PDF_ENABLE_XFA |
options.m_pOCContext = |
@@ -252,15 +257,15 @@ FPDFDOC_InitFormFillEnvironment(FPDF_DOCUMENT document, |
return pDocument->GetSDKDoc()->GetEnv(); |
#endif |
- CPDFSDK_FormFillEnvironment* pEnv = |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
new CPDFSDK_FormFillEnvironment(pDocument, formInfo); |
#ifdef PDF_ENABLE_XFA |
- pDocument->SetSDKDoc(pEnv->GetSDKDocument()); |
- CPDFXFA_App::GetInstance()->AddFormFillEnv(pEnv); |
+ pDocument->SetSDKDoc(pFormFillEnv->GetSDKDocument()); |
+ CPDFXFA_App::GetInstance()->AddFormFillEnv(pFormFillEnv); |
#endif // PDF_ENABLE_XFA |
- return pEnv; |
+ return pFormFillEnv; |
} |
DLLEXPORT void STDCALL |
@@ -268,23 +273,22 @@ FPDFDOC_ExitFormFillEnvironment(FPDF_FORMHANDLE hHandle) { |
if (!hHandle) |
return; |
- CPDFSDK_FormFillEnvironment* pEnv = HandleToCPDFSDKEnvironment(hHandle); |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
#ifdef PDF_ENABLE_XFA |
- CPDFXFA_App::GetInstance()->RemoveFormFillEnv(pEnv); |
+ CPDFXFA_App::GetInstance()->RemoveFormFillEnv(pFormFillEnv); |
// Reset the focused annotations and remove the SDK document from the |
// XFA document. |
- if (CPDFSDK_Document* pSDKDoc = pEnv->GetSDKDocument()) { |
- pSDKDoc->ClearAllFocusedAnnots(); |
- // If the document was closed first, it's possible the XFA document |
- // is now a nullptr. |
- if (pSDKDoc->GetXFADocument()) |
- pSDKDoc->GetXFADocument()->SetSDKDoc(nullptr); |
- } |
+ pFormFillEnv->GetSDKDocument()->ClearAllFocusedAnnots(); |
+ // If the document was closed first, it's possible the XFA document |
+ // is now a nullptr. |
+ if (pFormFillEnv->GetSDKDocument()->GetXFADocument()) |
+ pFormFillEnv->GetSDKDocument()->GetXFADocument()->SetSDKDoc(nullptr); |
#endif // PDF_ENABLE_XFA |
- delete pEnv; |
+ delete pFormFillEnv; |
} |
DLLEXPORT FPDF_BOOL STDCALL FORM_OnMouseMove(FPDF_FORMHANDLE hHandle, |
@@ -388,11 +392,11 @@ DLLEXPORT FPDF_BOOL STDCALL FORM_OnChar(FPDF_FORMHANDLE hHandle, |
} |
DLLEXPORT FPDF_BOOL STDCALL FORM_ForceToKillFocus(FPDF_FORMHANDLE hHandle) { |
- CPDFSDK_Document* pSDKDoc = CPDFSDK_Document::FromFPDFFormHandle(hHandle); |
- if (!pSDKDoc) |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ if (!pFormFillEnv) |
return FALSE; |
- |
- return pSDKDoc->KillFocusAnnot(0); |
+ return pFormFillEnv->GetSDKDocument()->KillFocusAnnot(0); |
} |
DLLEXPORT void STDCALL FPDF_FFLDraw(FPDF_FORMHANDLE hHandle, |
@@ -662,42 +666,46 @@ DLLEXPORT void STDCALL FORM_OnBeforeClosePage(FPDF_PAGE page, |
if (!hHandle) |
return; |
- CPDFSDK_Document* pSDKDoc = |
- HandleToCPDFSDKEnvironment(hHandle)->GetSDKDocument(); |
- if (!pSDKDoc) |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ if (!pFormFillEnv) |
return; |
UnderlyingPageType* pPage = UnderlyingFromFPDFPage(page); |
if (!pPage) |
return; |
- CPDFSDK_PageView* pPageView = pSDKDoc->GetPageView(pPage, false); |
+ CPDFSDK_PageView* pPageView = |
+ pFormFillEnv->GetSDKDocument()->GetPageView(pPage, false); |
if (pPageView) { |
pPageView->SetValid(FALSE); |
// RemovePageView() takes care of the delete for us. |
- pSDKDoc->RemovePageView(pPage); |
+ pFormFillEnv->GetSDKDocument()->RemovePageView(pPage); |
} |
} |
DLLEXPORT void STDCALL FORM_DoDocumentJSAction(FPDF_FORMHANDLE hHandle) { |
- CPDFSDK_Document* pSDKDoc = CPDFSDK_Document::FromFPDFFormHandle(hHandle); |
- if (pSDKDoc && HandleToCPDFSDKEnvironment(hHandle)->IsJSInitiated()) |
- pSDKDoc->ProcJavascriptFun(); |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ if (pFormFillEnv && pFormFillEnv->IsJSInitiated()) |
+ pFormFillEnv->GetSDKDocument()->ProcJavascriptFun(); |
} |
DLLEXPORT void STDCALL FORM_DoDocumentOpenAction(FPDF_FORMHANDLE hHandle) { |
- CPDFSDK_Document* pSDKDoc = CPDFSDK_Document::FromFPDFFormHandle(hHandle); |
- if (pSDKDoc && HandleToCPDFSDKEnvironment(hHandle)->IsJSInitiated()) |
- pSDKDoc->ProcOpenAction(); |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ if (pFormFillEnv && pFormFillEnv->IsJSInitiated()) |
+ pFormFillEnv->GetSDKDocument()->ProcOpenAction(); |
} |
DLLEXPORT void STDCALL FORM_DoDocumentAAction(FPDF_FORMHANDLE hHandle, |
int aaType) { |
- CPDFSDK_Document* pSDKDoc = CPDFSDK_Document::FromFPDFFormHandle(hHandle); |
- if (!pSDKDoc) |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ if (!pFormFillEnv) |
return; |
- CPDF_Document* pDoc = pSDKDoc->GetPDFDocument(); |
+ CPDF_Document* pDoc = pFormFillEnv->GetSDKDocument()->GetPDFDocument(); |
CPDF_Dictionary* pDic = pDoc->GetRoot(); |
if (!pDic) |
return; |
@@ -708,7 +716,7 @@ DLLEXPORT void STDCALL FORM_DoDocumentAAction(FPDF_FORMHANDLE hHandle, |
CPDFSDK_ActionHandler* pActionHandler = |
HandleToCPDFSDKEnvironment(hHandle)->GetActionHander(); |
pActionHandler->DoAction_Document(action, (CPDF_AAction::AActionType)aaType, |
- pSDKDoc->GetEnv()); |
+ pFormFillEnv); |
} |
} |
@@ -718,8 +726,9 @@ DLLEXPORT void STDCALL FORM_DoPageAAction(FPDF_PAGE page, |
if (!hHandle) |
return; |
- CPDFSDK_Document* pSDKDoc = CPDFSDK_Document::FromFPDFFormHandle(hHandle); |
- if (!pSDKDoc) |
+ CPDFSDK_FormFillEnvironment* pFormFillEnv = |
+ HandleToCPDFSDKEnvironment(hHandle); |
+ if (!pFormFillEnv) |
return; |
UnderlyingPageType* pPage = UnderlyingFromFPDFPage(page); |
@@ -727,22 +736,23 @@ DLLEXPORT void STDCALL FORM_DoPageAAction(FPDF_PAGE page, |
if (!pPDFPage) |
return; |
- if (!pSDKDoc->GetPageView(pPage, false)) |
+ if (!pFormFillEnv->GetSDKDocument()->GetPageView(pPage, false)) |
return; |
- CPDFSDK_FormFillEnvironment* pEnv = pSDKDoc->GetEnv(); |
- CPDFSDK_ActionHandler* pActionHandler = pEnv->GetActionHander(); |
+ CPDFSDK_ActionHandler* pActionHandler = pFormFillEnv->GetActionHander(); |
CPDF_Dictionary* pPageDict = pPDFPage->m_pFormDict; |
CPDF_AAction aa(pPageDict->GetDictFor("AA")); |
if (FPDFPAGE_AACTION_OPEN == aaType) { |
if (aa.ActionExist(CPDF_AAction::OpenPage)) { |
CPDF_Action action = aa.GetAction(CPDF_AAction::OpenPage); |
- pActionHandler->DoAction_Page(action, CPDF_AAction::OpenPage, pEnv); |
+ pActionHandler->DoAction_Page(action, CPDF_AAction::OpenPage, |
+ pFormFillEnv); |
} |
} else { |
if (aa.ActionExist(CPDF_AAction::ClosePage)) { |
CPDF_Action action = aa.GetAction(CPDF_AAction::ClosePage); |
- pActionHandler->DoAction_Page(action, CPDF_AAction::ClosePage, pEnv); |
+ pActionHandler->DoAction_Page(action, CPDF_AAction::ClosePage, |
+ pFormFillEnv); |
} |
} |
} |