1 // Copyright 2016 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6 
7 #ifndef PUBLIC_FPDF_STRUCTTREE_H_
8 #define PUBLIC_FPDF_STRUCTTREE_H_
9 
10 // clang-format off
11 // NOLINTNEXTLINE(build/include)
12 #include "fpdfview.h"
13 
14 #ifdef __cplusplus
15 extern "C" {
16 #endif
17 
18 // Function: FPDF_StructTree_GetForPage
19 //          Get the structure tree for a page.
20 // Parameters:
21 //          page        -   Handle to the page, as returned by FPDF_LoadPage().
22 // Return value:
23 //          A handle to the structure tree or NULL on error.
24 FPDF_EXPORT FPDF_STRUCTTREE FPDF_CALLCONV
25 FPDF_StructTree_GetForPage(FPDF_PAGE page);
26 
27 // Function: FPDF_StructTree_Close
28 //          Release a resource allocated by FPDF_StructTree_GetForPage().
29 // Parameters:
30 //          struct_tree -   Handle to the structure tree, as returned by
31 //                          FPDF_StructTree_LoadPage().
32 // Return value:
33 //          None.
34 FPDF_EXPORT void FPDF_CALLCONV
35 FPDF_StructTree_Close(FPDF_STRUCTTREE struct_tree);
36 
37 // Function: FPDF_StructTree_CountChildren
38 //          Count the number of children for the structure tree.
39 // Parameters:
40 //          struct_tree -   Handle to the structure tree, as returned by
41 //                          FPDF_StructTree_LoadPage().
42 // Return value:
43 //          The number of children, or -1 on error.
44 FPDF_EXPORT int FPDF_CALLCONV
45 FPDF_StructTree_CountChildren(FPDF_STRUCTTREE struct_tree);
46 
47 // Function: FPDF_StructTree_GetChildAtIndex
48 //          Get a child in the structure tree.
49 // Parameters:
50 //          struct_tree -   Handle to the structure tree, as returned by
51 //                          FPDF_StructTree_LoadPage().
52 //          index       -   The index for the child, 0-based.
53 // Return value:
54 //          The child at the n-th index or NULL on error.
55 FPDF_EXPORT FPDF_STRUCTELEMENT FPDF_CALLCONV
56 FPDF_StructTree_GetChildAtIndex(FPDF_STRUCTTREE struct_tree, int index);
57 
58 // Function: FPDF_StructElement_GetAltText
59 //          Get the alt text for a given element.
60 // Parameters:
61 //          struct_element -   Handle to the struct element.
62 //          buffer         -   A buffer for output the alt text. May be NULL.
63 //          buflen         -   The length of the buffer, in bytes. May be 0.
64 // Return value:
65 //          The number of bytes in the title, including the terminating NUL
66 //          character. The number of bytes is returned regardless of the
67 //          |buffer| and |buflen| parameters.
68 // Comments:
69 //          Regardless of the platform, the |buffer| is always in UTF-16LE
70 //          encoding. The string is terminated by a UTF16 NUL character. If
71 //          |buflen| is less than the required length, or |buffer| is NULL,
72 //          |buffer| will not be modified.
73 FPDF_EXPORT unsigned long FPDF_CALLCONV
74 FPDF_StructElement_GetAltText(FPDF_STRUCTELEMENT struct_element,
75                               void* buffer,
76                               unsigned long buflen);
77 
78 // Function: FPDF_StructElement_GetMarkedContentID
79 //          Get the marked content ID for a given element.
80 // Parameters:
81 //          struct_element -   Handle to the struct element.
82 // Return value:
83 //          The marked content ID of the element. If no ID exists, returns
84 //          -1.
85 FPDF_EXPORT int FPDF_CALLCONV
86 FPDF_StructElement_GetMarkedContentID(FPDF_STRUCTELEMENT struct_element);
87 
88 // Function: FPDF_StructElement_GetType
89 //           Get the type (/S) for a given element.
90 // Parameters:
91 //           struct_element - Handle to the struct element.
92 //           buffer        - A buffer for output. May be NULL.
93 //           buflen        - The length of the buffer, in bytes. May be 0.
94 // Return value:
95 //           The number of bytes in the type, including the terminating NUL
96 //           character. The number of bytes is returned regardless of the
97 //           |buffer| and |buflen| parameters.
98 // Comments:
99 //           Regardless of the platform, the |buffer| is always in UTF-16LE
100 //           encoding. The string is terminated by a UTF16 NUL character. If
101 //           |buflen| is less than the required length, or |buffer| is NULL,
102 //           |buffer| will not be modified.
103 FPDF_EXPORT unsigned long FPDF_CALLCONV
104 FPDF_StructElement_GetType(FPDF_STRUCTELEMENT struct_element,
105                            void* buffer,
106                            unsigned long buflen);
107 
108 // Function: FPDF_StructElement_GetTitle
109 //           Get the title (/T) for a given element.
110 // Parameters:
111 //           struct_element - Handle to the struct element.
112 //           buffer         - A buffer for output. May be NULL.
113 //           buflen         - The length of the buffer, in bytes. May be 0.
114 // Return value:
115 //           The number of bytes in the title, including the terminating NUL
116 //           character. The number of bytes is returned regardless of the
117 //           |buffer| and |buflen| parameters.
118 // Comments:
119 //           Regardless of the platform, the |buffer| is always in UTF-16LE
120 //           encoding. The string is terminated by a UTF16 NUL character. If
121 //           |buflen| is less than the required length, or |buffer| is NULL,
122 //           |buffer| will not be modified.
123 FPDF_EXPORT unsigned long FPDF_CALLCONV
124 FPDF_StructElement_GetTitle(FPDF_STRUCTELEMENT struct_element,
125                             void* buffer,
126                             unsigned long buflen);
127 
128 // Function: FPDF_StructElement_CountChildren
129 //          Count the number of children for the structure element.
130 // Parameters:
131 //          struct_element -   Handle to the struct element.
132 // Return value:
133 //          The number of children, or -1 on error.
134 FPDF_EXPORT int FPDF_CALLCONV
135 FPDF_StructElement_CountChildren(FPDF_STRUCTELEMENT struct_element);
136 
137 // Function: FPDF_StructElement_GetChildAtIndex
138 //          Get a child in the structure element.
139 // Parameters:
140 //          struct_tree -   Handle to the struct element.
141 //          index       -   The index for the child, 0-based.
142 // Return value:
143 //          The child at the n-th index or NULL on error.
144 // Comments:
145 //          If the child exists but is not an element, then this function will
146 //          return NULL. This will also return NULL for out of bounds indices.
147 FPDF_EXPORT FPDF_STRUCTELEMENT FPDF_CALLCONV
148 FPDF_StructElement_GetChildAtIndex(FPDF_STRUCTELEMENT struct_element,
149                                    int index);
150 
151 #ifdef __cplusplus
152 }  // extern "C"
153 #endif
154 
155 #endif  // PUBLIC_FPDF_STRUCTTREE_H_
156