// Copyright 2019 PDFium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef PUBLIC_FPDF_JAVASCRIPT_H_ #define PUBLIC_FPDF_JAVASCRIPT_H_ // NOLINTNEXTLINE(build/include) #include "fpdfview.h" #ifdef __cplusplus extern "C" { #endif // __cplusplus // Experimental API. // Get the number of JavaScript actions in |document|. // // document - handle to a document. // // Returns the number of JavaScript actions in |document| or -1 on error. FPDF_EXPORT int FPDF_CALLCONV FPDFDoc_GetJavaScriptActionCount(FPDF_DOCUMENT document); // Experimental API. // Get the JavaScript action at |index| in |document|. // // document - handle to a document. // index - the index of the requested JavaScript action. // // Returns the handle to the JavaScript action, or NULL on failure. // Caller owns the returned handle and must close it with // FPDFDoc_CloseJavaScriptAction(). FPDF_EXPORT FPDF_JAVASCRIPT_ACTION FPDF_CALLCONV FPDFDoc_GetJavaScriptAction(FPDF_DOCUMENT document, int index); // Experimental API. // Close a loaded FPDF_JAVASCRIPT_ACTION object. // javascript - Handle to a JavaScript action. FPDF_EXPORT void FPDF_CALLCONV FPDFDoc_CloseJavaScriptAction(FPDF_JAVASCRIPT_ACTION javascript); // Experimental API. // Get the name from the |javascript| handle. |buffer| is only modified if // |buflen| is longer than the length of the name. On errors, |buffer| is // unmodified and the returned length is 0. // // javascript - handle to an JavaScript action. // buffer - buffer for holding the name, encoded in UTF-16LE. // buflen - length of the buffer in bytes. // // Returns the length of the JavaScript action name in bytes. FPDF_EXPORT unsigned long FPDF_CALLCONV FPDFJavaScriptAction_GetName(FPDF_JAVASCRIPT_ACTION javascript, FPDF_WCHAR* buffer, unsigned long buflen); // Experimental API. // Get the script from the |javascript| handle. |buffer| is only modified if // |buflen| is longer than the length of the script. On errors, |buffer| is // unmodified and the returned length is 0. // // javascript - handle to an JavaScript action. // buffer - buffer for holding the name, encoded in UTF-16LE. // buflen - length of the buffer in bytes. // // Returns the length of the JavaScript action name in bytes. FPDF_EXPORT unsigned long FPDF_CALLCONV FPDFJavaScriptAction_GetScript(FPDF_JAVASCRIPT_ACTION javascript, FPDF_WCHAR* buffer, unsigned long buflen); #ifdef __cplusplus } // extern "C" #endif // __cplusplus #endif // PUBLIC_FPDF_JAVASCRIPT_H_