Chromium Code Reviews| Index: fpdfsdk/javascript/Document.cpp |
| diff --git a/fpdfsdk/javascript/Document.cpp b/fpdfsdk/javascript/Document.cpp |
| index 161a5d09e97d31b522e8c3fca38b86a86d9f6da3..434414e683137451ed8d2fc80b1274605d9fdb68 100644 |
| --- a/fpdfsdk/javascript/Document.cpp |
| +++ b/fpdfsdk/javascript/Document.cpp |
| @@ -10,9 +10,11 @@ |
| #include "core/fpdfapi/fpdf_font/include/cpdf_font.h" |
| #include "core/fpdfapi/fpdf_page/include/cpdf_page.h" |
| +#include "core/fpdfapi/fpdf_parser/include/cpdf_array.h" |
| #include "core/fpdfapi/fpdf_parser/include/cpdf_document.h" |
| #include "core/fpdfapi/fpdf_parser/include/fpdf_parser_decode.h" |
| #include "core/fpdfdoc/include/cpdf_interform.h" |
| +#include "core/fpdfdoc/include/cpdf_nametree.h" |
| #include "fpdfsdk/include/fsdk_mgr.h" |
| #include "fpdfsdk/javascript/Field.h" |
| #include "fpdfsdk/javascript/Icon.h" |
| @@ -124,6 +126,7 @@ JS_STATIC_METHOD_ENTRY(getPageNthWordQuads) |
| JS_STATIC_METHOD_ENTRY(getPageNumWords) |
| JS_STATIC_METHOD_ENTRY(getPrintParams) |
| JS_STATIC_METHOD_ENTRY(getURL) |
| +JS_STATIC_METHOD_ENTRY(gotoNamedDest) |
| JS_STATIC_METHOD_ENTRY(importAnFDF) |
| JS_STATIC_METHOD_ENTRY(importAnXFDF) |
| JS_STATIC_METHOD_ENTRY(importTextData) |
| @@ -1466,6 +1469,49 @@ FX_BOOL Document::getURL(IJS_Context* cc, |
| return TRUE; |
| } |
| +FX_BOOL Document::gotoNamedDest(IJS_Context* cc, |
| + const std::vector<CJS_Value>& params, |
| + CJS_Value& vRet, |
| + CFX_WideString& sError) { |
| + CJS_Context* pContext = (CJS_Context*)cc; |
| + if (params.size() != 1) { |
| + sError = JSGetStringFromID(pContext, IDS_STRING_JSPARAMERROR); |
| + return FALSE; |
| + } |
| + |
| + CPDF_Document* pDocument = m_pDocument->GetPDFDocument(); |
| + if (!pDocument) |
| + return FALSE; |
| + |
| + CFX_WideString wideName = params[0].ToCFXWideString(); |
| + CFX_ByteString utf16Name = wideName.UTF8Encode(); |
|
Tom Sepez
2016/08/08 22:05:24
nit: naming? Odd that the result of UTF8Encode wou
|
| + |
| + CPDF_NameTree nameTree(pDocument, "Dests"); |
| + CPDF_Array* destArray = nameTree.LookupNamedDest(pDocument, utf16Name); |
| + if (!destArray) |
| + return FALSE; |
| + |
| + CPDF_Dest dest(destArray); |
| + const CPDF_Array* arrayObject = ToArray(dest.GetObject()); |
| + |
| + std::unique_ptr<float[]> scrollPositionArray; |
| + int scrollPositionArraySize = 0; |
| + |
| + if (arrayObject) { |
| + scrollPositionArray = |
|
Tom Sepez
2016/08/08 22:05:24
nit: generally the technique to use here is:
s
|
| + std::unique_ptr<float[]>(new float[arrayObject->GetCount()]); |
| + int j = 0; |
| + for (size_t i = 2; i < arrayObject->GetCount(); i++) |
| + scrollPositionArray[j++] = arrayObject->GetFloatAt(i); |
| + scrollPositionArraySize = j; |
| + } |
| + |
| + CPDFDoc_Environment* pApp = m_pDocument->GetEnv(); |
| + pApp->FFI_DoGoToAction(dest.GetPageIndex(pDocument), dest.GetZoomMode(), |
| + scrollPositionArray.get(), scrollPositionArraySize); |
| + return TRUE; |
| +} |
| + |
| void Document::AddDelayData(CJS_DelayData* pData) { |
| m_DelayData.push_back(std::unique_ptr<CJS_DelayData>(pData)); |
| } |