Chromium Code Reviews| Index: fpdfsdk/fsdk_mgr.cpp |
| diff --git a/fpdfsdk/fsdk_mgr.cpp b/fpdfsdk/fsdk_mgr.cpp |
| index 835439394de0ad70f2f61b7d1bf0048635f2b318..c4c0384b44cf2fdc33006bd51612d362bf28b43d 100644 |
| --- a/fpdfsdk/fsdk_mgr.cpp |
| +++ b/fpdfsdk/fsdk_mgr.cpp |
| @@ -34,11 +34,17 @@ |
| #include <ctime> |
| #endif |
| +namespace { |
| + |
| +// NOTE: |bsUTF16LE| must outlive the use of the result. Care must be taken |
| +// since modifying the result would impact |bsUTF16LE|. |
| FPDF_WIDESTRING AsFPDFWideString(CFX_ByteString* bsUTF16LE) { |
| return reinterpret_cast<FPDF_WIDESTRING>( |
| bsUTF16LE->GetBuffer(bsUTF16LE->GetLength())); |
| } |
| +} // namespace |
| + |
| CPDFDoc_Environment::CPDFDoc_Environment(UnderlyingDocumentType* pDoc, |
| FPDF_FORMFILLINFO* pFFinfo) |
| : m_pInfo(pFFinfo), m_pSDKDoc(nullptr), m_pUnderlyingDoc(pDoc) { |
| @@ -988,19 +994,26 @@ void CPDFSDK_PageView::UpdateView(CPDFSDK_Annot* pAnnot) { |
| rcWindow.bottom); |
| } |
| -int CPDFSDK_PageView::GetPageIndex() { |
| - if (m_page) { |
| +int CPDFSDK_PageView::GetPageIndex() const { |
| + if (!m_page) |
| + return -1; |
| + |
| #ifdef PDF_ENABLE_XFA |
| - CPDF_Dictionary* pDic = m_page->GetPDFPage()->m_pFormDict; |
|
Lei Zhang
2016/06/08 07:33:56
GetPDFPage() is only valid for non-dynamic docs.
|
| -#else // PDF_ENABLE_XFA |
| - CPDF_Dictionary* pDic = m_page->m_pFormDict; |
| -#endif // PDF_ENABLE_XFA |
| - CPDF_Document* pDoc = m_pSDKDoc->GetPDFDocument(); |
| - if (pDoc && pDic) { |
| - return pDoc->GetPageIndex(pDic->GetObjNum()); |
| + int nDocType = m_page->GetDocument()->GetDocType(); |
| + switch (nDocType) { |
| + case DOCTYPE_DYNAMIC_XFA: { |
| + CXFA_FFPageView* pPageView = m_page->GetXFAPageView(); |
| + return pPageView ? pPageView->GetPageIndex() : -1; |
| } |
| + case DOCTYPE_STATIC_XFA: |
| + case DOCTYPE_PDF: |
| + return GetPageIndexForStaticPDF(); |
| + default: |
| + return -1; |
| } |
| - return -1; |
| +#else // PDF_ENABLE_XFA |
| + return GetPageIndexForStaticPDF(); |
| +#endif // PDF_ENABLE_XFA |
| } |
| bool CPDFSDK_PageView::IsValidAnnot(const CPDF_Annot* p) const { |
| @@ -1022,3 +1035,14 @@ CPDFSDK_Annot* CPDFSDK_PageView::GetFocusAnnot() { |
| } |
| return nullptr; |
| } |
| + |
| +int CPDFSDK_PageView::GetPageIndexForStaticPDF() const { |
| +#ifdef PDF_ENABLE_XFA |
| + CPDF_Page* pPage = m_page->GetPDFPage(); |
|
Lei Zhang
2016/06/08 07:33:56
Maybe we need CPDFPageFromUnderlyingPageType() ? F
|
| +#else // PDF_ENABLE_XFA |
| + CPDF_Page* pPage = m_page; |
| +#endif // PDF_ENABLE_XFA |
| + CPDF_Dictionary* pDict = pPage->m_pFormDict; |
| + CPDF_Document* pDoc = m_pSDKDoc->GetPDFDocument(); |
| + return (pDoc && pDict) ? pDoc->GetPageIndex(pDict->GetObjNum()) : -1; |
| +} |