xref: /aosp_15_r20/external/pdfium/public/fpdf_dataavail.h (revision 3ac0a46f773bac49fa9476ec2b1cf3f8da5ec3a4)
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