1*3ac0a46fSAndroid Build Coastguard Worker // Copyright 2014 The PDFium Authors 2*3ac0a46fSAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*3ac0a46fSAndroid Build Coastguard Worker // found in the LICENSE file. 4*3ac0a46fSAndroid Build Coastguard Worker 5*3ac0a46fSAndroid Build Coastguard Worker // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com 6*3ac0a46fSAndroid Build Coastguard Worker 7*3ac0a46fSAndroid Build Coastguard Worker #ifndef PUBLIC_FPDF_DATAAVAIL_H_ 8*3ac0a46fSAndroid Build Coastguard Worker #define PUBLIC_FPDF_DATAAVAIL_H_ 9*3ac0a46fSAndroid Build Coastguard Worker 10*3ac0a46fSAndroid Build Coastguard Worker #include <stddef.h> 11*3ac0a46fSAndroid Build Coastguard Worker 12*3ac0a46fSAndroid Build Coastguard Worker // NOLINTNEXTLINE(build/include) 13*3ac0a46fSAndroid Build Coastguard Worker #include "fpdfview.h" 14*3ac0a46fSAndroid Build Coastguard Worker 15*3ac0a46fSAndroid Build Coastguard Worker #define PDF_LINEARIZATION_UNKNOWN -1 16*3ac0a46fSAndroid Build Coastguard Worker #define PDF_NOT_LINEARIZED 0 17*3ac0a46fSAndroid Build Coastguard Worker #define PDF_LINEARIZED 1 18*3ac0a46fSAndroid Build Coastguard Worker 19*3ac0a46fSAndroid Build Coastguard Worker #define PDF_DATA_ERROR -1 20*3ac0a46fSAndroid Build Coastguard Worker #define PDF_DATA_NOTAVAIL 0 21*3ac0a46fSAndroid Build Coastguard Worker #define PDF_DATA_AVAIL 1 22*3ac0a46fSAndroid Build Coastguard Worker 23*3ac0a46fSAndroid Build Coastguard Worker #define PDF_FORM_ERROR -1 24*3ac0a46fSAndroid Build Coastguard Worker #define PDF_FORM_NOTAVAIL 0 25*3ac0a46fSAndroid Build Coastguard Worker #define PDF_FORM_AVAIL 1 26*3ac0a46fSAndroid Build Coastguard Worker #define PDF_FORM_NOTEXIST 2 27*3ac0a46fSAndroid Build Coastguard Worker 28*3ac0a46fSAndroid Build Coastguard Worker #ifdef __cplusplus 29*3ac0a46fSAndroid Build Coastguard Worker extern "C" { 30*3ac0a46fSAndroid Build Coastguard Worker #endif // __cplusplus 31*3ac0a46fSAndroid Build Coastguard Worker 32*3ac0a46fSAndroid Build Coastguard Worker // Interface for checking whether sections of the file are available. 33*3ac0a46fSAndroid Build Coastguard Worker typedef struct _FX_FILEAVAIL { 34*3ac0a46fSAndroid Build Coastguard Worker // Version number of the interface. Must be 1. 35*3ac0a46fSAndroid Build Coastguard Worker int version; 36*3ac0a46fSAndroid Build Coastguard Worker 37*3ac0a46fSAndroid Build Coastguard Worker // Reports if the specified data section is currently available. A section is 38*3ac0a46fSAndroid Build Coastguard Worker // available if all bytes in the section are available. 39*3ac0a46fSAndroid Build Coastguard Worker // 40*3ac0a46fSAndroid Build Coastguard Worker // Interface Version: 1 41*3ac0a46fSAndroid Build Coastguard Worker // Implementation Required: Yes 42*3ac0a46fSAndroid Build Coastguard Worker // 43*3ac0a46fSAndroid Build Coastguard Worker // pThis - pointer to the interface structure. 44*3ac0a46fSAndroid Build Coastguard Worker // offset - the offset of the data section in the file. 45*3ac0a46fSAndroid Build Coastguard Worker // size - the size of the data section. 46*3ac0a46fSAndroid Build Coastguard Worker // 47*3ac0a46fSAndroid Build Coastguard Worker // Returns true if the specified data section at |offset| of |size| 48*3ac0a46fSAndroid Build Coastguard Worker // is available. 49*3ac0a46fSAndroid Build Coastguard Worker FPDF_BOOL (*IsDataAvail)(struct _FX_FILEAVAIL* pThis, 50*3ac0a46fSAndroid Build Coastguard Worker size_t offset, 51*3ac0a46fSAndroid Build Coastguard Worker size_t size); 52*3ac0a46fSAndroid Build Coastguard Worker } FX_FILEAVAIL; 53*3ac0a46fSAndroid Build Coastguard Worker 54*3ac0a46fSAndroid Build Coastguard Worker // Create a document availability provider. 55*3ac0a46fSAndroid Build Coastguard Worker // 56*3ac0a46fSAndroid Build Coastguard Worker // file_avail - pointer to file availability interface. 57*3ac0a46fSAndroid Build Coastguard Worker // file - pointer to a file access interface. 58*3ac0a46fSAndroid Build Coastguard Worker // 59*3ac0a46fSAndroid Build Coastguard Worker // Returns a handle to the document availability provider, or NULL on error. 60*3ac0a46fSAndroid Build Coastguard Worker // 61*3ac0a46fSAndroid Build Coastguard Worker // FPDFAvail_Destroy() must be called when done with the availability provider. 62*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_AVAIL FPDF_CALLCONV FPDFAvail_Create(FX_FILEAVAIL* file_avail, 63*3ac0a46fSAndroid Build Coastguard Worker FPDF_FILEACCESS* file); 64*3ac0a46fSAndroid Build Coastguard Worker 65*3ac0a46fSAndroid Build Coastguard Worker // Destroy the |avail| document availability provider. 66*3ac0a46fSAndroid Build Coastguard Worker // 67*3ac0a46fSAndroid Build Coastguard Worker // avail - handle to document availability provider to be destroyed. 68*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT void FPDF_CALLCONV FPDFAvail_Destroy(FPDF_AVAIL avail); 69*3ac0a46fSAndroid Build Coastguard Worker 70*3ac0a46fSAndroid Build Coastguard Worker // Download hints interface. Used to receive hints for further downloading. 71*3ac0a46fSAndroid Build Coastguard Worker typedef struct _FX_DOWNLOADHINTS { 72*3ac0a46fSAndroid Build Coastguard Worker // Version number of the interface. Must be 1. 73*3ac0a46fSAndroid Build Coastguard Worker int version; 74*3ac0a46fSAndroid Build Coastguard Worker 75*3ac0a46fSAndroid Build Coastguard Worker // Add a section to be downloaded. 76*3ac0a46fSAndroid Build Coastguard Worker // 77*3ac0a46fSAndroid Build Coastguard Worker // Interface Version: 1 78*3ac0a46fSAndroid Build Coastguard Worker // Implementation Required: Yes 79*3ac0a46fSAndroid Build Coastguard Worker // 80*3ac0a46fSAndroid Build Coastguard Worker // pThis - pointer to the interface structure. 81*3ac0a46fSAndroid Build Coastguard Worker // offset - the offset of the hint reported to be downloaded. 82*3ac0a46fSAndroid Build Coastguard Worker // size - the size of the hint reported to be downloaded. 83*3ac0a46fSAndroid Build Coastguard Worker // 84*3ac0a46fSAndroid Build Coastguard Worker // The |offset| and |size| of the section may not be unique. Part of the 85*3ac0a46fSAndroid Build Coastguard Worker // section might be already available. The download manager must deal with 86*3ac0a46fSAndroid Build Coastguard Worker // overlapping sections. 87*3ac0a46fSAndroid Build Coastguard Worker void (*AddSegment)(struct _FX_DOWNLOADHINTS* pThis, 88*3ac0a46fSAndroid Build Coastguard Worker size_t offset, 89*3ac0a46fSAndroid Build Coastguard Worker size_t size); 90*3ac0a46fSAndroid Build Coastguard Worker } FX_DOWNLOADHINTS; 91*3ac0a46fSAndroid Build Coastguard Worker 92*3ac0a46fSAndroid Build Coastguard Worker // Checks if the document is ready for loading, if not, gets download hints. 93*3ac0a46fSAndroid Build Coastguard Worker // 94*3ac0a46fSAndroid Build Coastguard Worker // avail - handle to document availability provider. 95*3ac0a46fSAndroid Build Coastguard Worker // hints - pointer to a download hints interface. 96*3ac0a46fSAndroid Build Coastguard Worker // 97*3ac0a46fSAndroid Build Coastguard Worker // Returns one of: 98*3ac0a46fSAndroid Build Coastguard Worker // PDF_DATA_ERROR: A common error is returned. Data availability unknown. 99*3ac0a46fSAndroid Build Coastguard Worker // PDF_DATA_NOTAVAIL: Data not yet available. 100*3ac0a46fSAndroid Build Coastguard Worker // PDF_DATA_AVAIL: Data available. 101*3ac0a46fSAndroid Build Coastguard Worker // 102*3ac0a46fSAndroid Build Coastguard Worker // Applications should call this function whenever new data arrives, and process 103*3ac0a46fSAndroid Build Coastguard Worker // all the generated download hints, if any, until the function returns 104*3ac0a46fSAndroid Build Coastguard Worker // |PDF_DATA_ERROR| or |PDF_DATA_AVAIL|. 105*3ac0a46fSAndroid Build Coastguard Worker // if hints is nullptr, the function just check current document availability. 106*3ac0a46fSAndroid Build Coastguard Worker // 107*3ac0a46fSAndroid Build Coastguard Worker // Once all data is available, call FPDFAvail_GetDocument() to get a document 108*3ac0a46fSAndroid Build Coastguard Worker // handle. 109*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT int FPDF_CALLCONV FPDFAvail_IsDocAvail(FPDF_AVAIL avail, 110*3ac0a46fSAndroid Build Coastguard Worker FX_DOWNLOADHINTS* hints); 111*3ac0a46fSAndroid Build Coastguard Worker 112*3ac0a46fSAndroid Build Coastguard Worker // Get document from the availability provider. 113*3ac0a46fSAndroid Build Coastguard Worker // 114*3ac0a46fSAndroid Build Coastguard Worker // avail - handle to document availability provider. 115*3ac0a46fSAndroid Build Coastguard Worker // password - password for decrypting the PDF file. Optional. 116*3ac0a46fSAndroid Build Coastguard Worker // 117*3ac0a46fSAndroid Build Coastguard Worker // Returns a handle to the document. 118*3ac0a46fSAndroid Build Coastguard Worker // 119*3ac0a46fSAndroid Build Coastguard Worker // When FPDFAvail_IsDocAvail() returns TRUE, call FPDFAvail_GetDocument() to 120*3ac0a46fSAndroid Build Coastguard Worker // retrieve the document handle. 121*3ac0a46fSAndroid Build Coastguard Worker // See the comments for FPDF_LoadDocument() regarding the encoding for 122*3ac0a46fSAndroid Build Coastguard Worker // |password|. 123*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_DOCUMENT FPDF_CALLCONV 124*3ac0a46fSAndroid Build Coastguard Worker FPDFAvail_GetDocument(FPDF_AVAIL avail, FPDF_BYTESTRING password); 125*3ac0a46fSAndroid Build Coastguard Worker 126*3ac0a46fSAndroid Build Coastguard Worker // Get the page number for the first available page in a linearized PDF. 127*3ac0a46fSAndroid Build Coastguard Worker // 128*3ac0a46fSAndroid Build Coastguard Worker // doc - document handle. 129*3ac0a46fSAndroid Build Coastguard Worker // 130*3ac0a46fSAndroid Build Coastguard Worker // Returns the zero-based index for the first available page. 131*3ac0a46fSAndroid Build Coastguard Worker // 132*3ac0a46fSAndroid Build Coastguard Worker // For most linearized PDFs, the first available page will be the first page, 133*3ac0a46fSAndroid Build Coastguard Worker // however, some PDFs might make another page the first available page. 134*3ac0a46fSAndroid Build Coastguard Worker // For non-linearized PDFs, this function will always return zero. 135*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT int FPDF_CALLCONV FPDFAvail_GetFirstPageNum(FPDF_DOCUMENT doc); 136*3ac0a46fSAndroid Build Coastguard Worker 137*3ac0a46fSAndroid Build Coastguard Worker // Check if |page_index| is ready for loading, if not, get the 138*3ac0a46fSAndroid Build Coastguard Worker // |FX_DOWNLOADHINTS|. 139*3ac0a46fSAndroid Build Coastguard Worker // 140*3ac0a46fSAndroid Build Coastguard Worker // avail - handle to document availability provider. 141*3ac0a46fSAndroid Build Coastguard Worker // page_index - index number of the page. Zero for the first page. 142*3ac0a46fSAndroid Build Coastguard Worker // hints - pointer to a download hints interface. Populated if 143*3ac0a46fSAndroid Build Coastguard Worker // |page_index| is not available. 144*3ac0a46fSAndroid Build Coastguard Worker // 145*3ac0a46fSAndroid Build Coastguard Worker // Returns one of: 146*3ac0a46fSAndroid Build Coastguard Worker // PDF_DATA_ERROR: A common error is returned. Data availability unknown. 147*3ac0a46fSAndroid Build Coastguard Worker // PDF_DATA_NOTAVAIL: Data not yet available. 148*3ac0a46fSAndroid Build Coastguard Worker // PDF_DATA_AVAIL: Data available. 149*3ac0a46fSAndroid Build Coastguard Worker // 150*3ac0a46fSAndroid Build Coastguard Worker // This function can be called only after FPDFAvail_GetDocument() is called. 151*3ac0a46fSAndroid Build Coastguard Worker // Applications should call this function whenever new data arrives and process 152*3ac0a46fSAndroid Build Coastguard Worker // all the generated download |hints|, if any, until this function returns 153*3ac0a46fSAndroid Build Coastguard Worker // |PDF_DATA_ERROR| or |PDF_DATA_AVAIL|. Applications can then perform page 154*3ac0a46fSAndroid Build Coastguard Worker // loading. 155*3ac0a46fSAndroid Build Coastguard Worker // if hints is nullptr, the function just check current availability of 156*3ac0a46fSAndroid Build Coastguard Worker // specified page. 157*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT int FPDF_CALLCONV FPDFAvail_IsPageAvail(FPDF_AVAIL avail, 158*3ac0a46fSAndroid Build Coastguard Worker int page_index, 159*3ac0a46fSAndroid Build Coastguard Worker FX_DOWNLOADHINTS* hints); 160*3ac0a46fSAndroid Build Coastguard Worker 161*3ac0a46fSAndroid Build Coastguard Worker // Check if form data is ready for initialization, if not, get the 162*3ac0a46fSAndroid Build Coastguard Worker // |FX_DOWNLOADHINTS|. 163*3ac0a46fSAndroid Build Coastguard Worker // 164*3ac0a46fSAndroid Build Coastguard Worker // avail - handle to document availability provider. 165*3ac0a46fSAndroid Build Coastguard Worker // hints - pointer to a download hints interface. Populated if form is not 166*3ac0a46fSAndroid Build Coastguard Worker // ready for initialization. 167*3ac0a46fSAndroid Build Coastguard Worker // 168*3ac0a46fSAndroid Build Coastguard Worker // Returns one of: 169*3ac0a46fSAndroid Build Coastguard Worker // PDF_FORM_ERROR: A common eror, in general incorrect parameters. 170*3ac0a46fSAndroid Build Coastguard Worker // PDF_FORM_NOTAVAIL: Data not available. 171*3ac0a46fSAndroid Build Coastguard Worker // PDF_FORM_AVAIL: Data available. 172*3ac0a46fSAndroid Build Coastguard Worker // PDF_FORM_NOTEXIST: No form data. 173*3ac0a46fSAndroid Build Coastguard Worker // 174*3ac0a46fSAndroid Build Coastguard Worker // This function can be called only after FPDFAvail_GetDocument() is called. 175*3ac0a46fSAndroid Build Coastguard Worker // The application should call this function whenever new data arrives and 176*3ac0a46fSAndroid Build Coastguard Worker // process all the generated download |hints|, if any, until the function 177*3ac0a46fSAndroid Build Coastguard Worker // |PDF_FORM_ERROR|, |PDF_FORM_AVAIL| or |PDF_FORM_NOTEXIST|. 178*3ac0a46fSAndroid Build Coastguard Worker // if hints is nullptr, the function just check current form availability. 179*3ac0a46fSAndroid Build Coastguard Worker // 180*3ac0a46fSAndroid Build Coastguard Worker // Applications can then perform page loading. It is recommend to call 181*3ac0a46fSAndroid Build Coastguard Worker // FPDFDOC_InitFormFillEnvironment() when |PDF_FORM_AVAIL| is returned. 182*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT int FPDF_CALLCONV FPDFAvail_IsFormAvail(FPDF_AVAIL avail, 183*3ac0a46fSAndroid Build Coastguard Worker FX_DOWNLOADHINTS* hints); 184*3ac0a46fSAndroid Build Coastguard Worker 185*3ac0a46fSAndroid Build Coastguard Worker // Check whether a document is a linearized PDF. 186*3ac0a46fSAndroid Build Coastguard Worker // 187*3ac0a46fSAndroid Build Coastguard Worker // avail - handle to document availability provider. 188*3ac0a46fSAndroid Build Coastguard Worker // 189*3ac0a46fSAndroid Build Coastguard Worker // Returns one of: 190*3ac0a46fSAndroid Build Coastguard Worker // PDF_LINEARIZED 191*3ac0a46fSAndroid Build Coastguard Worker // PDF_NOT_LINEARIZED 192*3ac0a46fSAndroid Build Coastguard Worker // PDF_LINEARIZATION_UNKNOWN 193*3ac0a46fSAndroid Build Coastguard Worker // 194*3ac0a46fSAndroid Build Coastguard Worker // FPDFAvail_IsLinearized() will return |PDF_LINEARIZED| or |PDF_NOT_LINEARIZED| 195*3ac0a46fSAndroid Build Coastguard Worker // when we have 1k of data. If the files size less than 1k, it returns 196*3ac0a46fSAndroid Build Coastguard Worker // |PDF_LINEARIZATION_UNKNOWN| as there is insufficient information to determine 197*3ac0a46fSAndroid Build Coastguard Worker // if the PDF is linearlized. 198*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT int FPDF_CALLCONV FPDFAvail_IsLinearized(FPDF_AVAIL avail); 199*3ac0a46fSAndroid Build Coastguard Worker 200*3ac0a46fSAndroid Build Coastguard Worker #ifdef __cplusplus 201*3ac0a46fSAndroid Build Coastguard Worker } // extern "C" 202*3ac0a46fSAndroid Build Coastguard Worker #endif // __cplusplus 203*3ac0a46fSAndroid Build Coastguard Worker 204*3ac0a46fSAndroid Build Coastguard Worker #endif // PUBLIC_FPDF_DATAAVAIL_H_ 205