pdf2json 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (473) hide show
  1. data/README.markdown +9 -0
  2. data/bin/.gitkeep +0 -0
  3. data/ext/extconf.rb +30 -0
  4. data/lib/pdf2json.rb +8 -0
  5. data/pdf2json-0.52-source/AUTHORS +24 -0
  6. data/pdf2json-0.52-source/CHANGES +11 -0
  7. data/pdf2json-0.52-source/Makefile +84 -0
  8. data/pdf2json-0.52-source/Makefile.in +84 -0
  9. data/pdf2json-0.52-source/aclocal.m4 +274 -0
  10. data/pdf2json-0.52-source/aconf-win32.h +86 -0
  11. data/pdf2json-0.52-source/aconf.h +42 -0
  12. data/pdf2json-0.52-source/aconf.h.in +41 -0
  13. data/pdf2json-0.52-source/autom4te.cache/output.0 +6908 -0
  14. data/pdf2json-0.52-source/autom4te.cache/requests +76 -0
  15. data/pdf2json-0.52-source/autom4te.cache/traces.0 +466 -0
  16. data/pdf2json-0.52-source/config.log +1259 -0
  17. data/pdf2json-0.52-source/config.status +1050 -0
  18. data/pdf2json-0.52-source/configure +6908 -0
  19. data/pdf2json-0.52-source/configure.ac +93 -0
  20. data/pdf2json-0.52-source/doc/pdffonts.1 +130 -0
  21. data/pdf2json-0.52-source/doc/pdffonts.cat +107 -0
  22. data/pdf2json-0.52-source/doc/pdffonts.hlp +117 -0
  23. data/pdf2json-0.52-source/doc/pdfimages.1 +102 -0
  24. data/pdf2json-0.52-source/doc/pdfimages.cat +92 -0
  25. data/pdf2json-0.52-source/doc/pdfimages.hlp +101 -0
  26. data/pdf2json-0.52-source/doc/pdfinfo.1 +158 -0
  27. data/pdf2json-0.52-source/doc/pdfinfo.cat +119 -0
  28. data/pdf2json-0.52-source/doc/pdfinfo.hlp +129 -0
  29. data/pdf2json-0.52-source/doc/pdftoppm.1 +115 -0
  30. data/pdf2json-0.52-source/doc/pdftoppm.cat +105 -0
  31. data/pdf2json-0.52-source/doc/pdftoppm.hlp +114 -0
  32. data/pdf2json-0.52-source/doc/pdftops.1 +229 -0
  33. data/pdf2json-0.52-source/doc/pdftops.cat +221 -0
  34. data/pdf2json-0.52-source/doc/pdftops.hlp +231 -0
  35. data/pdf2json-0.52-source/doc/pdftotext.1 +137 -0
  36. data/pdf2json-0.52-source/doc/pdftotext.cat +120 -0
  37. data/pdf2json-0.52-source/doc/pdftotext.hlp +133 -0
  38. data/pdf2json-0.52-source/doc/sample-xpdfrc +91 -0
  39. data/pdf2json-0.52-source/doc/xpdf.1 +513 -0
  40. data/pdf2json-0.52-source/doc/xpdf.cat +476 -0
  41. data/pdf2json-0.52-source/doc/xpdf.hlp +489 -0
  42. data/pdf2json-0.52-source/doc/xpdfrc.5 +480 -0
  43. data/pdf2json-0.52-source/doc/xpdfrc.cat +474 -0
  44. data/pdf2json-0.52-source/doc/xpdfrc.hlp +479 -0
  45. data/pdf2json-0.52-source/fofi/.DS_Store +0 -0
  46. data/pdf2json-0.52-source/fofi/FoFiBase.cc +156 -0
  47. data/pdf2json-0.52-source/fofi/FoFiBase.h +57 -0
  48. data/pdf2json-0.52-source/fofi/FoFiBase.o +0 -0
  49. data/pdf2json-0.52-source/fofi/FoFiEncodings.cc +994 -0
  50. data/pdf2json-0.52-source/fofi/FoFiEncodings.h +36 -0
  51. data/pdf2json-0.52-source/fofi/FoFiEncodings.o +0 -0
  52. data/pdf2json-0.52-source/fofi/FoFiTrueType.cc +2027 -0
  53. data/pdf2json-0.52-source/fofi/FoFiTrueType.h +174 -0
  54. data/pdf2json-0.52-source/fofi/FoFiTrueType.o +0 -0
  55. data/pdf2json-0.52-source/fofi/FoFiType1.cc +252 -0
  56. data/pdf2json-0.52-source/fofi/FoFiType1.h +59 -0
  57. data/pdf2json-0.52-source/fofi/FoFiType1.o +0 -0
  58. data/pdf2json-0.52-source/fofi/FoFiType1C.cc +2603 -0
  59. data/pdf2json-0.52-source/fofi/FoFiType1C.h +233 -0
  60. data/pdf2json-0.52-source/fofi/FoFiType1C.o +0 -0
  61. data/pdf2json-0.52-source/fofi/Makefile +70 -0
  62. data/pdf2json-0.52-source/fofi/Makefile.dep +0 -0
  63. data/pdf2json-0.52-source/fofi/Makefile.in +70 -0
  64. data/pdf2json-0.52-source/fofi/libfofi.a +0 -0
  65. data/pdf2json-0.52-source/fofi/vms_make.com +0 -0
  66. data/pdf2json-0.52-source/freetype.win32/.DS_Store +0 -0
  67. data/pdf2json-0.52-source/freetype.win32/include/.DS_Store +0 -0
  68. data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftconfig.h +528 -0
  69. data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftheader.h +780 -0
  70. data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftmodule.h +32 -0
  71. data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftoption.h +733 -0
  72. data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftstdlib.h +173 -0
  73. data/pdf2json-0.52-source/freetype.win32/include/freetype/freetype.h +3919 -0
  74. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftadvanc.h +179 -0
  75. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftbbox.h +94 -0
  76. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftbdf.h +209 -0
  77. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftbitmap.h +227 -0
  78. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftcache.h +1128 -0
  79. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftchapters.h +103 -0
  80. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftcid.h +166 -0
  81. data/pdf2json-0.52-source/freetype.win32/include/freetype/fterrdef.h +244 -0
  82. data/pdf2json-0.52-source/freetype.win32/include/freetype/fterrors.h +206 -0
  83. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftgasp.h +120 -0
  84. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftglyph.h +613 -0
  85. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftgxval.h +358 -0
  86. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftgzip.h +102 -0
  87. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftimage.h +1313 -0
  88. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftincrem.h +353 -0
  89. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftlcdfil.h +213 -0
  90. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftlist.h +277 -0
  91. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftlzw.h +99 -0
  92. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmac.h +274 -0
  93. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmm.h +378 -0
  94. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmodapi.h +483 -0
  95. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmoderr.h +155 -0
  96. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftotval.h +203 -0
  97. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftoutln.h +537 -0
  98. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftpfr.h +172 -0
  99. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftrender.h +230 -0
  100. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsizes.h +159 -0
  101. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsnames.h +200 -0
  102. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftstroke.h +716 -0
  103. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsynth.h +80 -0
  104. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsystem.h +347 -0
  105. data/pdf2json-0.52-source/freetype.win32/include/freetype/fttrigon.h +350 -0
  106. data/pdf2json-0.52-source/freetype.win32/include/freetype/fttypes.h +588 -0
  107. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftwinfnt.h +274 -0
  108. data/pdf2json-0.52-source/freetype.win32/include/freetype/ftxf86.h +83 -0
  109. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/autohint.h +231 -0
  110. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftcalc.h +179 -0
  111. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftdebug.h +250 -0
  112. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftdriver.h +422 -0
  113. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftgloadr.h +168 -0
  114. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftmemory.h +380 -0
  115. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftobjs.h +1428 -0
  116. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftpic.h +67 -0
  117. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftrfork.h +196 -0
  118. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftserv.h +620 -0
  119. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftstream.h +539 -0
  120. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/fttrace.h +139 -0
  121. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftvalid.h +150 -0
  122. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/internal.h +51 -0
  123. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/pcftypes.h +56 -0
  124. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/psaux.h +873 -0
  125. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/pshints.h +712 -0
  126. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svbdf.h +77 -0
  127. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svcid.h +83 -0
  128. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svgldict.h +82 -0
  129. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svgxval.h +72 -0
  130. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svkern.h +51 -0
  131. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svmm.h +104 -0
  132. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svotval.h +55 -0
  133. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpfr.h +66 -0
  134. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpostnm.h +79 -0
  135. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpscmap.h +164 -0
  136. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpsinfo.h +92 -0
  137. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svsfnt.h +102 -0
  138. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svttcmap.h +106 -0
  139. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svtteng.h +53 -0
  140. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svttglyf.h +67 -0
  141. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svwinfnt.h +50 -0
  142. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svxf86nm.h +55 -0
  143. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/sfnt.h +897 -0
  144. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/t1types.h +270 -0
  145. data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/tttypes.h +1543 -0
  146. data/pdf2json-0.52-source/freetype.win32/include/freetype/t1tables.h +504 -0
  147. data/pdf2json-0.52-source/freetype.win32/include/freetype/ttnameid.h +1247 -0
  148. data/pdf2json-0.52-source/freetype.win32/include/freetype/tttables.h +759 -0
  149. data/pdf2json-0.52-source/freetype.win32/include/freetype/tttags.h +107 -0
  150. data/pdf2json-0.52-source/freetype.win32/include/freetype/ttunpat.h +59 -0
  151. data/pdf2json-0.52-source/freetype.win32/include/ft2build.h +39 -0
  152. data/pdf2json-0.52-source/freetype.win32/lib/freetype_a.lib +0 -0
  153. data/pdf2json-0.52-source/goo/.DS_Store +0 -0
  154. data/pdf2json-0.52-source/goo/FixedPoint.cc +118 -0
  155. data/pdf2json-0.52-source/goo/FixedPoint.h +155 -0
  156. data/pdf2json-0.52-source/goo/FixedPoint.o +0 -0
  157. data/pdf2json-0.52-source/goo/GHash.cc +380 -0
  158. data/pdf2json-0.52-source/goo/GHash.h +78 -0
  159. data/pdf2json-0.52-source/goo/GHash.o +0 -0
  160. data/pdf2json-0.52-source/goo/GList.cc +97 -0
  161. data/pdf2json-0.52-source/goo/GList.h +96 -0
  162. data/pdf2json-0.52-source/goo/GList.o +0 -0
  163. data/pdf2json-0.52-source/goo/GMutex.h +49 -0
  164. data/pdf2json-0.52-source/goo/GString.cc +724 -0
  165. data/pdf2json-0.52-source/goo/GString.cc.fixed +718 -0
  166. data/pdf2json-0.52-source/goo/GString.h +136 -0
  167. data/pdf2json-0.52-source/goo/GString.o +0 -0
  168. data/pdf2json-0.52-source/goo/ImgWriter.o +0 -0
  169. data/pdf2json-0.52-source/goo/JpegWriter.o +0 -0
  170. data/pdf2json-0.52-source/goo/Makefile +72 -0
  171. data/pdf2json-0.52-source/goo/Makefile.dep +0 -0
  172. data/pdf2json-0.52-source/goo/Makefile.in +72 -0
  173. data/pdf2json-0.52-source/goo/PNGWriter.o +0 -0
  174. data/pdf2json-0.52-source/goo/gfile.cc +731 -0
  175. data/pdf2json-0.52-source/goo/gfile.h +138 -0
  176. data/pdf2json-0.52-source/goo/gfile.o +0 -0
  177. data/pdf2json-0.52-source/goo/gmem.cc +264 -0
  178. data/pdf2json-0.52-source/goo/gmem.h +79 -0
  179. data/pdf2json-0.52-source/goo/gmem.o +0 -0
  180. data/pdf2json-0.52-source/goo/gmempp.cc +32 -0
  181. data/pdf2json-0.52-source/goo/gmempp.o +0 -0
  182. data/pdf2json-0.52-source/goo/gtypes.h +29 -0
  183. data/pdf2json-0.52-source/goo/libGoo.a +0 -0
  184. data/pdf2json-0.52-source/goo/parseargs.c +190 -0
  185. data/pdf2json-0.52-source/goo/parseargs.h +71 -0
  186. data/pdf2json-0.52-source/goo/parseargs.o +0 -0
  187. data/pdf2json-0.52-source/goo/vms_directory.c +214 -0
  188. data/pdf2json-0.52-source/goo/vms_dirent.h +67 -0
  189. data/pdf2json-0.52-source/goo/vms_make.com +82 -0
  190. data/pdf2json-0.52-source/goo/vms_sys_dirent.h +54 -0
  191. data/pdf2json-0.52-source/goo/vms_unix_time.h +102 -0
  192. data/pdf2json-0.52-source/goo/vms_unix_times.c +42 -0
  193. data/pdf2json-0.52-source/goo/vms_unlink.c +22 -0
  194. data/pdf2json-0.52-source/ms_make.bat +199 -0
  195. data/pdf2json-0.52-source/splash/.DS_Store +0 -0
  196. data/pdf2json-0.52-source/splash/Makefile +103 -0
  197. data/pdf2json-0.52-source/splash/Makefile.dep +0 -0
  198. data/pdf2json-0.52-source/splash/Makefile.in +103 -0
  199. data/pdf2json-0.52-source/splash/Splash.cc +3310 -0
  200. data/pdf2json-0.52-source/splash/Splash.h +293 -0
  201. data/pdf2json-0.52-source/splash/Splash.o +0 -0
  202. data/pdf2json-0.52-source/splash/SplashBitmap.cc +188 -0
  203. data/pdf2json-0.52-source/splash/SplashBitmap.h +64 -0
  204. data/pdf2json-0.52-source/splash/SplashBitmap.o +0 -0
  205. data/pdf2json-0.52-source/splash/SplashClip.cc +382 -0
  206. data/pdf2json-0.52-source/splash/SplashClip.h +107 -0
  207. data/pdf2json-0.52-source/splash/SplashClip.o +0 -0
  208. data/pdf2json-0.52-source/splash/SplashErrorCodes.h +32 -0
  209. data/pdf2json-0.52-source/splash/SplashFTFont.cc +357 -0
  210. data/pdf2json-0.52-source/splash/SplashFTFont.h +58 -0
  211. data/pdf2json-0.52-source/splash/SplashFTFont.o +0 -0
  212. data/pdf2json-0.52-source/splash/SplashFTFontEngine.cc +179 -0
  213. data/pdf2json-0.52-source/splash/SplashFTFontEngine.h +65 -0
  214. data/pdf2json-0.52-source/splash/SplashFTFontEngine.o +0 -0
  215. data/pdf2json-0.52-source/splash/SplashFTFontFile.cc +114 -0
  216. data/pdf2json-0.52-source/splash/SplashFTFontFile.h +73 -0
  217. data/pdf2json-0.52-source/splash/SplashFTFontFile.o +0 -0
  218. data/pdf2json-0.52-source/splash/SplashFont.cc +176 -0
  219. data/pdf2json-0.52-source/splash/SplashFont.h +104 -0
  220. data/pdf2json-0.52-source/splash/SplashFont.o +0 -0
  221. data/pdf2json-0.52-source/splash/SplashFontEngine.cc +317 -0
  222. data/pdf2json-0.52-source/splash/SplashFontEngine.h +91 -0
  223. data/pdf2json-0.52-source/splash/SplashFontEngine.o +0 -0
  224. data/pdf2json-0.52-source/splash/SplashFontFile.cc +55 -0
  225. data/pdf2json-0.52-source/splash/SplashFontFile.h +60 -0
  226. data/pdf2json-0.52-source/splash/SplashFontFile.o +0 -0
  227. data/pdf2json-0.52-source/splash/SplashFontFileID.cc +23 -0
  228. data/pdf2json-0.52-source/splash/SplashFontFileID.h +30 -0
  229. data/pdf2json-0.52-source/splash/SplashFontFileID.o +0 -0
  230. data/pdf2json-0.52-source/splash/SplashGlyphBitmap.h +26 -0
  231. data/pdf2json-0.52-source/splash/SplashMath.h +89 -0
  232. data/pdf2json-0.52-source/splash/SplashPath.cc +184 -0
  233. data/pdf2json-0.52-source/splash/SplashPath.h +121 -0
  234. data/pdf2json-0.52-source/splash/SplashPath.o +0 -0
  235. data/pdf2json-0.52-source/splash/SplashPattern.cc +40 -0
  236. data/pdf2json-0.52-source/splash/SplashPattern.h +65 -0
  237. data/pdf2json-0.52-source/splash/SplashPattern.o +0 -0
  238. data/pdf2json-0.52-source/splash/SplashScreen.cc +383 -0
  239. data/pdf2json-0.52-source/splash/SplashScreen.h +56 -0
  240. data/pdf2json-0.52-source/splash/SplashScreen.o +0 -0
  241. data/pdf2json-0.52-source/splash/SplashState.cc +165 -0
  242. data/pdf2json-0.52-source/splash/SplashState.h +103 -0
  243. data/pdf2json-0.52-source/splash/SplashState.o +0 -0
  244. data/pdf2json-0.52-source/splash/SplashT1Font.cc +287 -0
  245. data/pdf2json-0.52-source/splash/SplashT1Font.h +57 -0
  246. data/pdf2json-0.52-source/splash/SplashT1Font.o +0 -0
  247. data/pdf2json-0.52-source/splash/SplashT1FontEngine.cc +124 -0
  248. data/pdf2json-0.52-source/splash/SplashT1FontEngine.h +53 -0
  249. data/pdf2json-0.52-source/splash/SplashT1FontEngine.o +0 -0
  250. data/pdf2json-0.52-source/splash/SplashT1FontFile.cc +97 -0
  251. data/pdf2json-0.52-source/splash/SplashT1FontFile.h +58 -0
  252. data/pdf2json-0.52-source/splash/SplashT1FontFile.o +0 -0
  253. data/pdf2json-0.52-source/splash/SplashTypes.h +132 -0
  254. data/pdf2json-0.52-source/splash/SplashXPath.cc +438 -0
  255. data/pdf2json-0.52-source/splash/SplashXPath.h +100 -0
  256. data/pdf2json-0.52-source/splash/SplashXPath.o +0 -0
  257. data/pdf2json-0.52-source/splash/SplashXPathScanner.cc +428 -0
  258. data/pdf2json-0.52-source/splash/SplashXPathScanner.h +87 -0
  259. data/pdf2json-0.52-source/splash/SplashXPathScanner.o +0 -0
  260. data/pdf2json-0.52-source/splash/libsplash.a +0 -0
  261. data/pdf2json-0.52-source/splash/vms_make.com +0 -0
  262. data/pdf2json-0.52-source/src/.DS_Store +0 -0
  263. data/pdf2json-0.52-source/src/GVector.h +101 -0
  264. data/pdf2json-0.52-source/src/ImgOutputDev.cc +1243 -0
  265. data/pdf2json-0.52-source/src/ImgOutputDev.h +307 -0
  266. data/pdf2json-0.52-source/src/ImgOutputDev.o +0 -0
  267. data/pdf2json-0.52-source/src/Makefile +68 -0
  268. data/pdf2json-0.52-source/src/Makefile.in +68 -0
  269. data/pdf2json-0.52-source/src/XmlFonts.cc +367 -0
  270. data/pdf2json-0.52-source/src/XmlFonts.h +91 -0
  271. data/pdf2json-0.52-source/src/XmlFonts.o +0 -0
  272. data/pdf2json-0.52-source/src/XmlLinks.cc +101 -0
  273. data/pdf2json-0.52-source/src/XmlLinks.h +54 -0
  274. data/pdf2json-0.52-source/src/XmlLinks.o +0 -0
  275. data/pdf2json-0.52-source/src/pdf2json +0 -0
  276. data/pdf2json-0.52-source/src/pdf2json.cc +343 -0
  277. data/pdf2json-0.52-source/src/pdf2json.o +0 -0
  278. data/pdf2json-0.52-source/src/pdf2xml.dtd +22 -0
  279. data/pdf2json-0.52-source/src/pdf2xmljson.dtd +9 -0
  280. data/pdf2json-0.52-source/xpdf/.DS_Store +0 -0
  281. data/pdf2json-0.52-source/xpdf/Annot.cc +1556 -0
  282. data/pdf2json-0.52-source/xpdf/Annot.h +142 -0
  283. data/pdf2json-0.52-source/xpdf/Annot.o +0 -0
  284. data/pdf2json-0.52-source/xpdf/Array.cc +73 -0
  285. data/pdf2json-0.52-source/xpdf/Array.h +58 -0
  286. data/pdf2json-0.52-source/xpdf/Array.o +0 -0
  287. data/pdf2json-0.52-source/xpdf/BuiltinFont.cc +65 -0
  288. data/pdf2json-0.52-source/xpdf/BuiltinFont.h +57 -0
  289. data/pdf2json-0.52-source/xpdf/BuiltinFont.o +0 -0
  290. data/pdf2json-0.52-source/xpdf/BuiltinFontTables.cc +4284 -0
  291. data/pdf2json-0.52-source/xpdf/BuiltinFontTables.h +23 -0
  292. data/pdf2json-0.52-source/xpdf/BuiltinFontTables.o +0 -0
  293. data/pdf2json-0.52-source/xpdf/CMap.cc +408 -0
  294. data/pdf2json-0.52-source/xpdf/CMap.h +102 -0
  295. data/pdf2json-0.52-source/xpdf/CMap.o +0 -0
  296. data/pdf2json-0.52-source/xpdf/Catalog.cc +374 -0
  297. data/pdf2json-0.52-source/xpdf/Catalog.h +97 -0
  298. data/pdf2json-0.52-source/xpdf/Catalog.o +0 -0
  299. data/pdf2json-0.52-source/xpdf/CharCodeToUnicode.cc +540 -0
  300. data/pdf2json-0.52-source/xpdf/CharCodeToUnicode.h +117 -0
  301. data/pdf2json-0.52-source/xpdf/CharCodeToUnicode.o +0 -0
  302. data/pdf2json-0.52-source/xpdf/CharTypes.h +24 -0
  303. data/pdf2json-0.52-source/xpdf/CompactFontTables.h +464 -0
  304. data/pdf2json-0.52-source/xpdf/CoreOutputDev.cc +61 -0
  305. data/pdf2json-0.52-source/xpdf/CoreOutputDev.h +61 -0
  306. data/pdf2json-0.52-source/xpdf/Decrypt.cc +776 -0
  307. data/pdf2json-0.52-source/xpdf/Decrypt.h +95 -0
  308. data/pdf2json-0.52-source/xpdf/Decrypt.o +0 -0
  309. data/pdf2json-0.52-source/xpdf/Dict.cc +95 -0
  310. data/pdf2json-0.52-source/xpdf/Dict.h +77 -0
  311. data/pdf2json-0.52-source/xpdf/Dict.o +0 -0
  312. data/pdf2json-0.52-source/xpdf/Error.cc +38 -0
  313. data/pdf2json-0.52-source/xpdf/Error.h +23 -0
  314. data/pdf2json-0.52-source/xpdf/Error.o +0 -0
  315. data/pdf2json-0.52-source/xpdf/ErrorCodes.h +36 -0
  316. data/pdf2json-0.52-source/xpdf/FontEncodingTables.cc +1824 -0
  317. data/pdf2json-0.52-source/xpdf/FontEncodingTables.h +20 -0
  318. data/pdf2json-0.52-source/xpdf/FontEncodingTables.o +0 -0
  319. data/pdf2json-0.52-source/xpdf/Function.cc +1573 -0
  320. data/pdf2json-0.52-source/xpdf/Function.h +229 -0
  321. data/pdf2json-0.52-source/xpdf/Function.o +0 -0
  322. data/pdf2json-0.52-source/xpdf/Gfx.cc +4187 -0
  323. data/pdf2json-0.52-source/xpdf/Gfx.h +312 -0
  324. data/pdf2json-0.52-source/xpdf/Gfx.o +0 -0
  325. data/pdf2json-0.52-source/xpdf/GfxFont.cc +1568 -0
  326. data/pdf2json-0.52-source/xpdf/GfxFont.h +320 -0
  327. data/pdf2json-0.52-source/xpdf/GfxFont.o +0 -0
  328. data/pdf2json-0.52-source/xpdf/GfxState.cc +4137 -0
  329. data/pdf2json-0.52-source/xpdf/GfxState.h +1244 -0
  330. data/pdf2json-0.52-source/xpdf/GfxState.o +0 -0
  331. data/pdf2json-0.52-source/xpdf/GlobalParams.cc +2924 -0
  332. data/pdf2json-0.52-source/xpdf/GlobalParams.cc.old +2908 -0
  333. data/pdf2json-0.52-source/xpdf/GlobalParams.h +466 -0
  334. data/pdf2json-0.52-source/xpdf/GlobalParams.h.old +463 -0
  335. data/pdf2json-0.52-source/xpdf/GlobalParams.o +0 -0
  336. data/pdf2json-0.52-source/xpdf/ImageOutputDev.cc +195 -0
  337. data/pdf2json-0.52-source/xpdf/ImageOutputDev.h +76 -0
  338. data/pdf2json-0.52-source/xpdf/ImageOutputDev.o +0 -0
  339. data/pdf2json-0.52-source/xpdf/JArithmeticDecoder.cc +322 -0
  340. data/pdf2json-0.52-source/xpdf/JArithmeticDecoder.h +109 -0
  341. data/pdf2json-0.52-source/xpdf/JArithmeticDecoder.o +0 -0
  342. data/pdf2json-0.52-source/xpdf/JBIG2Stream.cc +3413 -0
  343. data/pdf2json-0.52-source/xpdf/JBIG2Stream.h +145 -0
  344. data/pdf2json-0.52-source/xpdf/JBIG2Stream.o +0 -0
  345. data/pdf2json-0.52-source/xpdf/JPXStream.cc +3144 -0
  346. data/pdf2json-0.52-source/xpdf/JPXStream.h +351 -0
  347. data/pdf2json-0.52-source/xpdf/JPXStream.o +0 -0
  348. data/pdf2json-0.52-source/xpdf/Lexer.cc +485 -0
  349. data/pdf2json-0.52-source/xpdf/Lexer.h +80 -0
  350. data/pdf2json-0.52-source/xpdf/Lexer.o +0 -0
  351. data/pdf2json-0.52-source/xpdf/Link.cc +806 -0
  352. data/pdf2json-0.52-source/xpdf/Link.cc.old +784 -0
  353. data/pdf2json-0.52-source/xpdf/Link.h +415 -0
  354. data/pdf2json-0.52-source/xpdf/Link.h.old +369 -0
  355. data/pdf2json-0.52-source/xpdf/Link.o +0 -0
  356. data/pdf2json-0.52-source/xpdf/Makefile +232 -0
  357. data/pdf2json-0.52-source/xpdf/Makefile.dep +0 -0
  358. data/pdf2json-0.52-source/xpdf/Makefile.in +232 -0
  359. data/pdf2json-0.52-source/xpdf/NameToCharCode.cc +116 -0
  360. data/pdf2json-0.52-source/xpdf/NameToCharCode.h +42 -0
  361. data/pdf2json-0.52-source/xpdf/NameToCharCode.o +0 -0
  362. data/pdf2json-0.52-source/xpdf/NameToUnicodeTable.h +1097 -0
  363. data/pdf2json-0.52-source/xpdf/Object.cc +231 -0
  364. data/pdf2json-0.52-source/xpdf/Object.h +303 -0
  365. data/pdf2json-0.52-source/xpdf/Object.o +0 -0
  366. data/pdf2json-0.52-source/xpdf/Outline.cc +151 -0
  367. data/pdf2json-0.52-source/xpdf/Outline.h +76 -0
  368. data/pdf2json-0.52-source/xpdf/Outline.o +0 -0
  369. data/pdf2json-0.52-source/xpdf/OutputDev.cc +131 -0
  370. data/pdf2json-0.52-source/xpdf/OutputDev.h +253 -0
  371. data/pdf2json-0.52-source/xpdf/OutputDev.o +0 -0
  372. data/pdf2json-0.52-source/xpdf/PDFCore.cc +2044 -0
  373. data/pdf2json-0.52-source/xpdf/PDFCore.h +321 -0
  374. data/pdf2json-0.52-source/xpdf/PDFDoc.cc +404 -0
  375. data/pdf2json-0.52-source/xpdf/PDFDoc.h +183 -0
  376. data/pdf2json-0.52-source/xpdf/PDFDoc.o +0 -0
  377. data/pdf2json-0.52-source/xpdf/PDFDocEncoding.cc +44 -0
  378. data/pdf2json-0.52-source/xpdf/PDFDocEncoding.h +16 -0
  379. data/pdf2json-0.52-source/xpdf/PDFDocEncoding.o +0 -0
  380. data/pdf2json-0.52-source/xpdf/PSOutputDev.cc +6224 -0
  381. data/pdf2json-0.52-source/xpdf/PSOutputDev.h +395 -0
  382. data/pdf2json-0.52-source/xpdf/PSOutputDev.o +0 -0
  383. data/pdf2json-0.52-source/xpdf/PSTokenizer.cc +135 -0
  384. data/pdf2json-0.52-source/xpdf/PSTokenizer.h +41 -0
  385. data/pdf2json-0.52-source/xpdf/PSTokenizer.o +0 -0
  386. data/pdf2json-0.52-source/xpdf/Page.cc +454 -0
  387. data/pdf2json-0.52-source/xpdf/Page.h +187 -0
  388. data/pdf2json-0.52-source/xpdf/Page.o +0 -0
  389. data/pdf2json-0.52-source/xpdf/Parser.cc +227 -0
  390. data/pdf2json-0.52-source/xpdf/Parser.h +59 -0
  391. data/pdf2json-0.52-source/xpdf/Parser.o +0 -0
  392. data/pdf2json-0.52-source/xpdf/PreScanOutputDev.cc +257 -0
  393. data/pdf2json-0.52-source/xpdf/PreScanOutputDev.h +130 -0
  394. data/pdf2json-0.52-source/xpdf/PreScanOutputDev.o +0 -0
  395. data/pdf2json-0.52-source/xpdf/SecurityHandler.cc +390 -0
  396. data/pdf2json-0.52-source/xpdf/SecurityHandler.h +160 -0
  397. data/pdf2json-0.52-source/xpdf/SecurityHandler.o +0 -0
  398. data/pdf2json-0.52-source/xpdf/SplashOutputDev.cc +2845 -0
  399. data/pdf2json-0.52-source/xpdf/SplashOutputDev.h +247 -0
  400. data/pdf2json-0.52-source/xpdf/SplashOutputDev.o +0 -0
  401. data/pdf2json-0.52-source/xpdf/Stream-CCITT.h +459 -0
  402. data/pdf2json-0.52-source/xpdf/Stream.cc +4627 -0
  403. data/pdf2json-0.52-source/xpdf/Stream.h +858 -0
  404. data/pdf2json-0.52-source/xpdf/Stream.o +0 -0
  405. data/pdf2json-0.52-source/xpdf/TextOutputDev.cc +4090 -0
  406. data/pdf2json-0.52-source/xpdf/TextOutputDev.h +661 -0
  407. data/pdf2json-0.52-source/xpdf/TextOutputDev.o +0 -0
  408. data/pdf2json-0.52-source/xpdf/UTF8.h +56 -0
  409. data/pdf2json-0.52-source/xpdf/UnicodeMap.cc +302 -0
  410. data/pdf2json-0.52-source/xpdf/UnicodeMap.cc.old +293 -0
  411. data/pdf2json-0.52-source/xpdf/UnicodeMap.h +135 -0
  412. data/pdf2json-0.52-source/xpdf/UnicodeMap.h.old +123 -0
  413. data/pdf2json-0.52-source/xpdf/UnicodeMap.o +0 -0
  414. data/pdf2json-0.52-source/xpdf/UnicodeMapTables.h +361 -0
  415. data/pdf2json-0.52-source/xpdf/UnicodeTypeTable.cc +949 -0
  416. data/pdf2json-0.52-source/xpdf/UnicodeTypeTable.h +20 -0
  417. data/pdf2json-0.52-source/xpdf/UnicodeTypeTable.o +0 -0
  418. data/pdf2json-0.52-source/xpdf/XPDFApp.cc +447 -0
  419. data/pdf2json-0.52-source/xpdf/XPDFApp.h +114 -0
  420. data/pdf2json-0.52-source/xpdf/XPDFCore.cc +1655 -0
  421. data/pdf2json-0.52-source/xpdf/XPDFCore.h +251 -0
  422. data/pdf2json-0.52-source/xpdf/XPDFTree.cc +931 -0
  423. data/pdf2json-0.52-source/xpdf/XPDFTree.h +45 -0
  424. data/pdf2json-0.52-source/xpdf/XPDFTreeP.h +87 -0
  425. data/pdf2json-0.52-source/xpdf/XPDFViewer.cc +3488 -0
  426. data/pdf2json-0.52-source/xpdf/XPDFViewer.h +352 -0
  427. data/pdf2json-0.52-source/xpdf/XRef.cc +896 -0
  428. data/pdf2json-0.52-source/xpdf/XRef.h +133 -0
  429. data/pdf2json-0.52-source/xpdf/XRef.o +0 -0
  430. data/pdf2json-0.52-source/xpdf/XpdfPluginAPI.cc +262 -0
  431. data/pdf2json-0.52-source/xpdf/XpdfPluginAPI.h +341 -0
  432. data/pdf2json-0.52-source/xpdf/XpdfPluginAPI.o +0 -0
  433. data/pdf2json-0.52-source/xpdf/about-text.h +48 -0
  434. data/pdf2json-0.52-source/xpdf/about.xbm +6 -0
  435. data/pdf2json-0.52-source/xpdf/backArrow.xbm +6 -0
  436. data/pdf2json-0.52-source/xpdf/backArrowDis.xbm +6 -0
  437. data/pdf2json-0.52-source/xpdf/config.h +112 -0
  438. data/pdf2json-0.52-source/xpdf/dblLeftArrow.xbm +6 -0
  439. data/pdf2json-0.52-source/xpdf/dblLeftArrowDis.xbm +6 -0
  440. data/pdf2json-0.52-source/xpdf/dblRightArrow.xbm +6 -0
  441. data/pdf2json-0.52-source/xpdf/dblRightArrowDis.xbm +6 -0
  442. data/pdf2json-0.52-source/xpdf/find.xbm +6 -0
  443. data/pdf2json-0.52-source/xpdf/findDis.xbm +6 -0
  444. data/pdf2json-0.52-source/xpdf/forwardArrow.xbm +6 -0
  445. data/pdf2json-0.52-source/xpdf/forwardArrowDis.xbm +6 -0
  446. data/pdf2json-0.52-source/xpdf/leftArrow.xbm +5 -0
  447. data/pdf2json-0.52-source/xpdf/leftArrowDis.xbm +5 -0
  448. data/pdf2json-0.52-source/xpdf/libXpdf.a +0 -0
  449. data/pdf2json-0.52-source/xpdf/pdffonts +0 -0
  450. data/pdf2json-0.52-source/xpdf/pdffonts.cc +298 -0
  451. data/pdf2json-0.52-source/xpdf/pdffonts.o +0 -0
  452. data/pdf2json-0.52-source/xpdf/pdfimages +0 -0
  453. data/pdf2json-0.52-source/xpdf/pdfimages.cc +155 -0
  454. data/pdf2json-0.52-source/xpdf/pdfimages.o +0 -0
  455. data/pdf2json-0.52-source/xpdf/pdfinfo +0 -0
  456. data/pdf2json-0.52-source/xpdf/pdfinfo.cc +387 -0
  457. data/pdf2json-0.52-source/xpdf/pdfinfo.o +0 -0
  458. data/pdf2json-0.52-source/xpdf/pdftoppm.cc +203 -0
  459. data/pdf2json-0.52-source/xpdf/pdftops +0 -0
  460. data/pdf2json-0.52-source/xpdf/pdftops.cc +344 -0
  461. data/pdf2json-0.52-source/xpdf/pdftops.o +0 -0
  462. data/pdf2json-0.52-source/xpdf/pdftotext +0 -0
  463. data/pdf2json-0.52-source/xpdf/pdftotext.cc +333 -0
  464. data/pdf2json-0.52-source/xpdf/pdftotext.o +0 -0
  465. data/pdf2json-0.52-source/xpdf/print.xbm +6 -0
  466. data/pdf2json-0.52-source/xpdf/printDis.xbm +6 -0
  467. data/pdf2json-0.52-source/xpdf/rightArrow.xbm +5 -0
  468. data/pdf2json-0.52-source/xpdf/rightArrowDis.xbm +5 -0
  469. data/pdf2json-0.52-source/xpdf/vms_make.com +129 -0
  470. data/pdf2json-0.52-source/xpdf/xpdf.cc +344 -0
  471. data/pdf2json-0.52-source/xpdf/xpdfIcon.xpm +62 -0
  472. data/pdf2json.gemspec +29 -0
  473. metadata +518 -0
@@ -0,0 +1,227 @@
1
+ /***************************************************************************/
2
+ /* */
3
+ /* ftbitmap.h */
4
+ /* */
5
+ /* FreeType utility functions for bitmaps (specification). */
6
+ /* */
7
+ /* Copyright 2004, 2005, 2006, 2008 by */
8
+ /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
+ /* */
10
+ /* This file is part of the FreeType project, and may only be used, */
11
+ /* modified, and distributed under the terms of the FreeType project */
12
+ /* license, LICENSE.TXT. By continuing to use, modify, or distribute */
13
+ /* this file you indicate that you have read the license and */
14
+ /* understand and accept it fully. */
15
+ /* */
16
+ /***************************************************************************/
17
+
18
+
19
+ #ifndef __FTBITMAP_H__
20
+ #define __FTBITMAP_H__
21
+
22
+
23
+ #include <ft2build.h>
24
+ #include FT_FREETYPE_H
25
+
26
+ #ifdef FREETYPE_H
27
+ #error "freetype.h of FreeType 1 has been loaded!"
28
+ #error "Please fix the directory search order for header files"
29
+ #error "so that freetype.h of FreeType 2 is found first."
30
+ #endif
31
+
32
+
33
+ FT_BEGIN_HEADER
34
+
35
+
36
+ /*************************************************************************/
37
+ /* */
38
+ /* <Section> */
39
+ /* bitmap_handling */
40
+ /* */
41
+ /* <Title> */
42
+ /* Bitmap Handling */
43
+ /* */
44
+ /* <Abstract> */
45
+ /* Handling FT_Bitmap objects. */
46
+ /* */
47
+ /* <Description> */
48
+ /* This section contains functions for converting FT_Bitmap objects. */
49
+ /* */
50
+ /*************************************************************************/
51
+
52
+
53
+ /*************************************************************************/
54
+ /* */
55
+ /* <Function> */
56
+ /* FT_Bitmap_New */
57
+ /* */
58
+ /* <Description> */
59
+ /* Initialize a pointer to an @FT_Bitmap structure. */
60
+ /* */
61
+ /* <InOut> */
62
+ /* abitmap :: A pointer to the bitmap structure. */
63
+ /* */
64
+ FT_EXPORT( void )
65
+ FT_Bitmap_New( FT_Bitmap *abitmap );
66
+
67
+
68
+ /*************************************************************************/
69
+ /* */
70
+ /* <Function> */
71
+ /* FT_Bitmap_Copy */
72
+ /* */
73
+ /* <Description> */
74
+ /* Copy a bitmap into another one. */
75
+ /* */
76
+ /* <Input> */
77
+ /* library :: A handle to a library object. */
78
+ /* */
79
+ /* source :: A handle to the source bitmap. */
80
+ /* */
81
+ /* <Output> */
82
+ /* target :: A handle to the target bitmap. */
83
+ /* */
84
+ /* <Return> */
85
+ /* FreeType error code. 0~means success. */
86
+ /* */
87
+ FT_EXPORT( FT_Error )
88
+ FT_Bitmap_Copy( FT_Library library,
89
+ const FT_Bitmap *source,
90
+ FT_Bitmap *target);
91
+
92
+
93
+ /*************************************************************************/
94
+ /* */
95
+ /* <Function> */
96
+ /* FT_Bitmap_Embolden */
97
+ /* */
98
+ /* <Description> */
99
+ /* Embolden a bitmap. The new bitmap will be about `xStrength' */
100
+ /* pixels wider and `yStrength' pixels higher. The left and bottom */
101
+ /* borders are kept unchanged. */
102
+ /* */
103
+ /* <Input> */
104
+ /* library :: A handle to a library object. */
105
+ /* */
106
+ /* xStrength :: How strong the glyph is emboldened horizontally. */
107
+ /* Expressed in 26.6 pixel format. */
108
+ /* */
109
+ /* yStrength :: How strong the glyph is emboldened vertically. */
110
+ /* Expressed in 26.6 pixel format. */
111
+ /* */
112
+ /* <InOut> */
113
+ /* bitmap :: A handle to the target bitmap. */
114
+ /* */
115
+ /* <Return> */
116
+ /* FreeType error code. 0~means success. */
117
+ /* */
118
+ /* <Note> */
119
+ /* The current implementation restricts `xStrength' to be less than */
120
+ /* or equal to~8 if bitmap is of pixel_mode @FT_PIXEL_MODE_MONO. */
121
+ /* */
122
+ /* If you want to embolden the bitmap owned by a @FT_GlyphSlotRec, */
123
+ /* you should call @FT_GlyphSlot_Own_Bitmap on the slot first. */
124
+ /* */
125
+ FT_EXPORT( FT_Error )
126
+ FT_Bitmap_Embolden( FT_Library library,
127
+ FT_Bitmap* bitmap,
128
+ FT_Pos xStrength,
129
+ FT_Pos yStrength );
130
+
131
+
132
+ /*************************************************************************/
133
+ /* */
134
+ /* <Function> */
135
+ /* FT_Bitmap_Convert */
136
+ /* */
137
+ /* <Description> */
138
+ /* Convert a bitmap object with depth 1bpp, 2bpp, 4bpp, or 8bpp to a */
139
+ /* bitmap object with depth 8bpp, making the number of used bytes per */
140
+ /* line (a.k.a. the `pitch') a multiple of `alignment'. */
141
+ /* */
142
+ /* <Input> */
143
+ /* library :: A handle to a library object. */
144
+ /* */
145
+ /* source :: The source bitmap. */
146
+ /* */
147
+ /* alignment :: The pitch of the bitmap is a multiple of this */
148
+ /* parameter. Common values are 1, 2, or 4. */
149
+ /* */
150
+ /* <Output> */
151
+ /* target :: The target bitmap. */
152
+ /* */
153
+ /* <Return> */
154
+ /* FreeType error code. 0~means success. */
155
+ /* */
156
+ /* <Note> */
157
+ /* It is possible to call @FT_Bitmap_Convert multiple times without */
158
+ /* calling @FT_Bitmap_Done (the memory is simply reallocated). */
159
+ /* */
160
+ /* Use @FT_Bitmap_Done to finally remove the bitmap object. */
161
+ /* */
162
+ /* The `library' argument is taken to have access to FreeType's */
163
+ /* memory handling functions. */
164
+ /* */
165
+ FT_EXPORT( FT_Error )
166
+ FT_Bitmap_Convert( FT_Library library,
167
+ const FT_Bitmap *source,
168
+ FT_Bitmap *target,
169
+ FT_Int alignment );
170
+
171
+
172
+ /*************************************************************************/
173
+ /* */
174
+ /* <Function> */
175
+ /* FT_GlyphSlot_Own_Bitmap */
176
+ /* */
177
+ /* <Description> */
178
+ /* Make sure that a glyph slot owns `slot->bitmap'. */
179
+ /* */
180
+ /* <Input> */
181
+ /* slot :: The glyph slot. */
182
+ /* */
183
+ /* <Return> */
184
+ /* FreeType error code. 0~means success. */
185
+ /* */
186
+ /* <Note> */
187
+ /* This function is to be used in combination with */
188
+ /* @FT_Bitmap_Embolden. */
189
+ /* */
190
+ FT_EXPORT( FT_Error )
191
+ FT_GlyphSlot_Own_Bitmap( FT_GlyphSlot slot );
192
+
193
+
194
+ /*************************************************************************/
195
+ /* */
196
+ /* <Function> */
197
+ /* FT_Bitmap_Done */
198
+ /* */
199
+ /* <Description> */
200
+ /* Destroy a bitmap object created with @FT_Bitmap_New. */
201
+ /* */
202
+ /* <Input> */
203
+ /* library :: A handle to a library object. */
204
+ /* */
205
+ /* bitmap :: The bitmap object to be freed. */
206
+ /* */
207
+ /* <Return> */
208
+ /* FreeType error code. 0~means success. */
209
+ /* */
210
+ /* <Note> */
211
+ /* The `library' argument is taken to have access to FreeType's */
212
+ /* memory handling functions. */
213
+ /* */
214
+ FT_EXPORT( FT_Error )
215
+ FT_Bitmap_Done( FT_Library library,
216
+ FT_Bitmap *bitmap );
217
+
218
+
219
+ /* */
220
+
221
+
222
+ FT_END_HEADER
223
+
224
+ #endif /* __FTBITMAP_H__ */
225
+
226
+
227
+ /* END */
@@ -0,0 +1,1128 @@
1
+ /***************************************************************************/
2
+ /* */
3
+ /* ftcache.h */
4
+ /* */
5
+ /* FreeType Cache subsystem (specification). */
6
+ /* */
7
+ /* Copyright 1996-2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2010 by */
8
+ /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
+ /* */
10
+ /* This file is part of the FreeType project, and may only be used, */
11
+ /* modified, and distributed under the terms of the FreeType project */
12
+ /* license, LICENSE.TXT. By continuing to use, modify, or distribute */
13
+ /* this file you indicate that you have read the license and */
14
+ /* understand and accept it fully. */
15
+ /* */
16
+ /***************************************************************************/
17
+
18
+
19
+ #ifndef __FTCACHE_H__
20
+ #define __FTCACHE_H__
21
+
22
+
23
+ #include <ft2build.h>
24
+ #include FT_GLYPH_H
25
+
26
+
27
+ FT_BEGIN_HEADER
28
+
29
+
30
+ /*************************************************************************
31
+ *
32
+ * <Section>
33
+ * cache_subsystem
34
+ *
35
+ * <Title>
36
+ * Cache Sub-System
37
+ *
38
+ * <Abstract>
39
+ * How to cache face, size, and glyph data with FreeType~2.
40
+ *
41
+ * <Description>
42
+ * This section describes the FreeType~2 cache sub-system, which is used
43
+ * to limit the number of concurrently opened @FT_Face and @FT_Size
44
+ * objects, as well as caching information like character maps and glyph
45
+ * images while limiting their maximum memory usage.
46
+ *
47
+ * Note that all types and functions begin with the `FTC_' prefix.
48
+ *
49
+ * The cache is highly portable and thus doesn't know anything about the
50
+ * fonts installed on your system, or how to access them. This implies
51
+ * the following scheme:
52
+ *
53
+ * First, available or installed font faces are uniquely identified by
54
+ * @FTC_FaceID values, provided to the cache by the client. Note that
55
+ * the cache only stores and compares these values, and doesn't try to
56
+ * interpret them in any way.
57
+ *
58
+ * Second, the cache calls, only when needed, a client-provided function
59
+ * to convert an @FTC_FaceID into a new @FT_Face object. The latter is
60
+ * then completely managed by the cache, including its termination
61
+ * through @FT_Done_Face. To monitor termination of face objects, the
62
+ * finalizer callback in the `generic' field of the @FT_Face object can
63
+ * be used, which might also be used to store the @FTC_FaceID of the
64
+ * face.
65
+ *
66
+ * Clients are free to map face IDs to anything else. The most simple
67
+ * usage is to associate them to a (pathname,face_index) pair that is
68
+ * used to call @FT_New_Face. However, more complex schemes are also
69
+ * possible.
70
+ *
71
+ * Note that for the cache to work correctly, the face ID values must be
72
+ * *persistent*, which means that the contents they point to should not
73
+ * change at runtime, or that their value should not become invalid.
74
+ *
75
+ * If this is unavoidable (e.g., when a font is uninstalled at runtime),
76
+ * you should call @FTC_Manager_RemoveFaceID as soon as possible, to let
77
+ * the cache get rid of any references to the old @FTC_FaceID it may
78
+ * keep internally. Failure to do so will lead to incorrect behaviour
79
+ * or even crashes.
80
+ *
81
+ * To use the cache, start with calling @FTC_Manager_New to create a new
82
+ * @FTC_Manager object, which models a single cache instance. You can
83
+ * then look up @FT_Face and @FT_Size objects with
84
+ * @FTC_Manager_LookupFace and @FTC_Manager_LookupSize, respectively.
85
+ *
86
+ * If you want to use the charmap caching, call @FTC_CMapCache_New, then
87
+ * later use @FTC_CMapCache_Lookup to perform the equivalent of
88
+ * @FT_Get_Char_Index, only much faster.
89
+ *
90
+ * If you want to use the @FT_Glyph caching, call @FTC_ImageCache, then
91
+ * later use @FTC_ImageCache_Lookup to retrieve the corresponding
92
+ * @FT_Glyph objects from the cache.
93
+ *
94
+ * If you need lots of small bitmaps, it is much more memory efficient
95
+ * to call @FTC_SBitCache_New followed by @FTC_SBitCache_Lookup. This
96
+ * returns @FTC_SBitRec structures, which are used to store small
97
+ * bitmaps directly. (A small bitmap is one whose metrics and
98
+ * dimensions all fit into 8-bit integers).
99
+ *
100
+ * We hope to also provide a kerning cache in the near future.
101
+ *
102
+ *
103
+ * <Order>
104
+ * FTC_Manager
105
+ * FTC_FaceID
106
+ * FTC_Face_Requester
107
+ *
108
+ * FTC_Manager_New
109
+ * FTC_Manager_Reset
110
+ * FTC_Manager_Done
111
+ * FTC_Manager_LookupFace
112
+ * FTC_Manager_LookupSize
113
+ * FTC_Manager_RemoveFaceID
114
+ *
115
+ * FTC_Node
116
+ * FTC_Node_Unref
117
+ *
118
+ * FTC_ImageCache
119
+ * FTC_ImageCache_New
120
+ * FTC_ImageCache_Lookup
121
+ *
122
+ * FTC_SBit
123
+ * FTC_SBitCache
124
+ * FTC_SBitCache_New
125
+ * FTC_SBitCache_Lookup
126
+ *
127
+ * FTC_CMapCache
128
+ * FTC_CMapCache_New
129
+ * FTC_CMapCache_Lookup
130
+ *
131
+ *************************************************************************/
132
+
133
+
134
+ /*************************************************************************/
135
+ /*************************************************************************/
136
+ /*************************************************************************/
137
+ /***** *****/
138
+ /***** BASIC TYPE DEFINITIONS *****/
139
+ /***** *****/
140
+ /*************************************************************************/
141
+ /*************************************************************************/
142
+ /*************************************************************************/
143
+
144
+
145
+ /*************************************************************************
146
+ *
147
+ * @type: FTC_FaceID
148
+ *
149
+ * @description:
150
+ * An opaque pointer type that is used to identity face objects. The
151
+ * contents of such objects is application-dependent.
152
+ *
153
+ * These pointers are typically used to point to a user-defined
154
+ * structure containing a font file path, and face index.
155
+ *
156
+ * @note:
157
+ * Never use NULL as a valid @FTC_FaceID.
158
+ *
159
+ * Face IDs are passed by the client to the cache manager, which calls,
160
+ * when needed, the @FTC_Face_Requester to translate them into new
161
+ * @FT_Face objects.
162
+ *
163
+ * If the content of a given face ID changes at runtime, or if the value
164
+ * becomes invalid (e.g., when uninstalling a font), you should
165
+ * immediately call @FTC_Manager_RemoveFaceID before any other cache
166
+ * function.
167
+ *
168
+ * Failure to do so will result in incorrect behaviour or even
169
+ * memory leaks and crashes.
170
+ */
171
+ typedef FT_Pointer FTC_FaceID;
172
+
173
+
174
+ /************************************************************************
175
+ *
176
+ * @functype:
177
+ * FTC_Face_Requester
178
+ *
179
+ * @description:
180
+ * A callback function provided by client applications. It is used by
181
+ * the cache manager to translate a given @FTC_FaceID into a new valid
182
+ * @FT_Face object, on demand.
183
+ *
184
+ * <Input>
185
+ * face_id ::
186
+ * The face ID to resolve.
187
+ *
188
+ * library ::
189
+ * A handle to a FreeType library object.
190
+ *
191
+ * req_data ::
192
+ * Application-provided request data (see note below).
193
+ *
194
+ * <Output>
195
+ * aface ::
196
+ * A new @FT_Face handle.
197
+ *
198
+ * <Return>
199
+ * FreeType error code. 0~means success.
200
+ *
201
+ * <Note>
202
+ * The third parameter `req_data' is the same as the one passed by the
203
+ * client when @FTC_Manager_New is called.
204
+ *
205
+ * The face requester should not perform funny things on the returned
206
+ * face object, like creating a new @FT_Size for it, or setting a
207
+ * transformation through @FT_Set_Transform!
208
+ */
209
+ typedef FT_Error
210
+ (*FTC_Face_Requester)( FTC_FaceID face_id,
211
+ FT_Library library,
212
+ FT_Pointer request_data,
213
+ FT_Face* aface );
214
+
215
+ /* */
216
+
217
+ #define FT_POINTER_TO_ULONG( p ) ( (FT_ULong)(FT_Pointer)(p) )
218
+
219
+ #define FTC_FACE_ID_HASH( i ) \
220
+ ((FT_UInt32)(( FT_POINTER_TO_ULONG( i ) >> 3 ) ^ \
221
+ ( FT_POINTER_TO_ULONG( i ) << 7 ) ) )
222
+
223
+
224
+ /*************************************************************************/
225
+ /*************************************************************************/
226
+ /*************************************************************************/
227
+ /***** *****/
228
+ /***** CACHE MANAGER OBJECT *****/
229
+ /***** *****/
230
+ /*************************************************************************/
231
+ /*************************************************************************/
232
+ /*************************************************************************/
233
+
234
+
235
+ /*************************************************************************/
236
+ /* */
237
+ /* <Type> */
238
+ /* FTC_Manager */
239
+ /* */
240
+ /* <Description> */
241
+ /* This object corresponds to one instance of the cache-subsystem. */
242
+ /* It is used to cache one or more @FT_Face objects, along with */
243
+ /* corresponding @FT_Size objects. */
244
+ /* */
245
+ /* The manager intentionally limits the total number of opened */
246
+ /* @FT_Face and @FT_Size objects to control memory usage. See the */
247
+ /* `max_faces' and `max_sizes' parameters of @FTC_Manager_New. */
248
+ /* */
249
+ /* The manager is also used to cache `nodes' of various types while */
250
+ /* limiting their total memory usage. */
251
+ /* */
252
+ /* All limitations are enforced by keeping lists of managed objects */
253
+ /* in most-recently-used order, and flushing old nodes to make room */
254
+ /* for new ones. */
255
+ /* */
256
+ typedef struct FTC_ManagerRec_* FTC_Manager;
257
+
258
+
259
+ /*************************************************************************/
260
+ /* */
261
+ /* <Type> */
262
+ /* FTC_Node */
263
+ /* */
264
+ /* <Description> */
265
+ /* An opaque handle to a cache node object. Each cache node is */
266
+ /* reference-counted. A node with a count of~0 might be flushed */
267
+ /* out of a full cache whenever a lookup request is performed. */
268
+ /* */
269
+ /* If you look up nodes, you have the ability to `acquire' them, */
270
+ /* i.e., to increment their reference count. This will prevent the */
271
+ /* node from being flushed out of the cache until you explicitly */
272
+ /* `release' it (see @FTC_Node_Unref). */
273
+ /* */
274
+ /* See also @FTC_SBitCache_Lookup and @FTC_ImageCache_Lookup. */
275
+ /* */
276
+ typedef struct FTC_NodeRec_* FTC_Node;
277
+
278
+
279
+ /*************************************************************************/
280
+ /* */
281
+ /* <Function> */
282
+ /* FTC_Manager_New */
283
+ /* */
284
+ /* <Description> */
285
+ /* Create a new cache manager. */
286
+ /* */
287
+ /* <Input> */
288
+ /* library :: The parent FreeType library handle to use. */
289
+ /* */
290
+ /* max_faces :: Maximum number of opened @FT_Face objects managed by */
291
+ /* this cache instance. Use~0 for defaults. */
292
+ /* */
293
+ /* max_sizes :: Maximum number of opened @FT_Size objects managed by */
294
+ /* this cache instance. Use~0 for defaults. */
295
+ /* */
296
+ /* max_bytes :: Maximum number of bytes to use for cached data nodes. */
297
+ /* Use~0 for defaults. Note that this value does not */
298
+ /* account for managed @FT_Face and @FT_Size objects. */
299
+ /* */
300
+ /* requester :: An application-provided callback used to translate */
301
+ /* face IDs into real @FT_Face objects. */
302
+ /* */
303
+ /* req_data :: A generic pointer that is passed to the requester */
304
+ /* each time it is called (see @FTC_Face_Requester). */
305
+ /* */
306
+ /* <Output> */
307
+ /* amanager :: A handle to a new manager object. 0~in case of */
308
+ /* failure. */
309
+ /* */
310
+ /* <Return> */
311
+ /* FreeType error code. 0~means success. */
312
+ /* */
313
+ FT_EXPORT( FT_Error )
314
+ FTC_Manager_New( FT_Library library,
315
+ FT_UInt max_faces,
316
+ FT_UInt max_sizes,
317
+ FT_ULong max_bytes,
318
+ FTC_Face_Requester requester,
319
+ FT_Pointer req_data,
320
+ FTC_Manager *amanager );
321
+
322
+
323
+ /*************************************************************************/
324
+ /* */
325
+ /* <Function> */
326
+ /* FTC_Manager_Reset */
327
+ /* */
328
+ /* <Description> */
329
+ /* Empty a given cache manager. This simply gets rid of all the */
330
+ /* currently cached @FT_Face and @FT_Size objects within the manager. */
331
+ /* */
332
+ /* <InOut> */
333
+ /* manager :: A handle to the manager. */
334
+ /* */
335
+ FT_EXPORT( void )
336
+ FTC_Manager_Reset( FTC_Manager manager );
337
+
338
+
339
+ /*************************************************************************/
340
+ /* */
341
+ /* <Function> */
342
+ /* FTC_Manager_Done */
343
+ /* */
344
+ /* <Description> */
345
+ /* Destroy a given manager after emptying it. */
346
+ /* */
347
+ /* <Input> */
348
+ /* manager :: A handle to the target cache manager object. */
349
+ /* */
350
+ FT_EXPORT( void )
351
+ FTC_Manager_Done( FTC_Manager manager );
352
+
353
+
354
+ /*************************************************************************/
355
+ /* */
356
+ /* <Function> */
357
+ /* FTC_Manager_LookupFace */
358
+ /* */
359
+ /* <Description> */
360
+ /* Retrieve the @FT_Face object that corresponds to a given face ID */
361
+ /* through a cache manager. */
362
+ /* */
363
+ /* <Input> */
364
+ /* manager :: A handle to the cache manager. */
365
+ /* */
366
+ /* face_id :: The ID of the face object. */
367
+ /* */
368
+ /* <Output> */
369
+ /* aface :: A handle to the face object. */
370
+ /* */
371
+ /* <Return> */
372
+ /* FreeType error code. 0~means success. */
373
+ /* */
374
+ /* <Note> */
375
+ /* The returned @FT_Face object is always owned by the manager. You */
376
+ /* should never try to discard it yourself. */
377
+ /* */
378
+ /* The @FT_Face object doesn't necessarily have a current size object */
379
+ /* (i.e., face->size can be 0). If you need a specific `font size', */
380
+ /* use @FTC_Manager_LookupSize instead. */
381
+ /* */
382
+ /* Never change the face's transformation matrix (i.e., never call */
383
+ /* the @FT_Set_Transform function) on a returned face! If you need */
384
+ /* to transform glyphs, do it yourself after glyph loading. */
385
+ /* */
386
+ /* When you perform a lookup, out-of-memory errors are detected */
387
+ /* _within_ the lookup and force incremental flushes of the cache */
388
+ /* until enough memory is released for the lookup to succeed. */
389
+ /* */
390
+ /* If a lookup fails with `FT_Err_Out_Of_Memory' the cache has */
391
+ /* already been completely flushed, and still no memory was available */
392
+ /* for the operation. */
393
+ /* */
394
+ FT_EXPORT( FT_Error )
395
+ FTC_Manager_LookupFace( FTC_Manager manager,
396
+ FTC_FaceID face_id,
397
+ FT_Face *aface );
398
+
399
+
400
+ /*************************************************************************/
401
+ /* */
402
+ /* <Struct> */
403
+ /* FTC_ScalerRec */
404
+ /* */
405
+ /* <Description> */
406
+ /* A structure used to describe a given character size in either */
407
+ /* pixels or points to the cache manager. See */
408
+ /* @FTC_Manager_LookupSize. */
409
+ /* */
410
+ /* <Fields> */
411
+ /* face_id :: The source face ID. */
412
+ /* */
413
+ /* width :: The character width. */
414
+ /* */
415
+ /* height :: The character height. */
416
+ /* */
417
+ /* pixel :: A Boolean. If 1, the `width' and `height' fields are */
418
+ /* interpreted as integer pixel character sizes. */
419
+ /* Otherwise, they are expressed as 1/64th of points. */
420
+ /* */
421
+ /* x_res :: Only used when `pixel' is value~0 to indicate the */
422
+ /* horizontal resolution in dpi. */
423
+ /* */
424
+ /* y_res :: Only used when `pixel' is value~0 to indicate the */
425
+ /* vertical resolution in dpi. */
426
+ /* */
427
+ /* <Note> */
428
+ /* This type is mainly used to retrieve @FT_Size objects through the */
429
+ /* cache manager. */
430
+ /* */
431
+ typedef struct FTC_ScalerRec_
432
+ {
433
+ FTC_FaceID face_id;
434
+ FT_UInt width;
435
+ FT_UInt height;
436
+ FT_Int pixel;
437
+ FT_UInt x_res;
438
+ FT_UInt y_res;
439
+
440
+ } FTC_ScalerRec;
441
+
442
+
443
+ /*************************************************************************/
444
+ /* */
445
+ /* <Struct> */
446
+ /* FTC_Scaler */
447
+ /* */
448
+ /* <Description> */
449
+ /* A handle to an @FTC_ScalerRec structure. */
450
+ /* */
451
+ typedef struct FTC_ScalerRec_* FTC_Scaler;
452
+
453
+
454
+ /*************************************************************************/
455
+ /* */
456
+ /* <Function> */
457
+ /* FTC_Manager_LookupSize */
458
+ /* */
459
+ /* <Description> */
460
+ /* Retrieve the @FT_Size object that corresponds to a given */
461
+ /* @FTC_ScalerRec pointer through a cache manager. */
462
+ /* */
463
+ /* <Input> */
464
+ /* manager :: A handle to the cache manager. */
465
+ /* */
466
+ /* scaler :: A scaler handle. */
467
+ /* */
468
+ /* <Output> */
469
+ /* asize :: A handle to the size object. */
470
+ /* */
471
+ /* <Return> */
472
+ /* FreeType error code. 0~means success. */
473
+ /* */
474
+ /* <Note> */
475
+ /* The returned @FT_Size object is always owned by the manager. You */
476
+ /* should never try to discard it by yourself. */
477
+ /* */
478
+ /* You can access the parent @FT_Face object simply as `size->face' */
479
+ /* if you need it. Note that this object is also owned by the */
480
+ /* manager. */
481
+ /* */
482
+ /* <Note> */
483
+ /* When you perform a lookup, out-of-memory errors are detected */
484
+ /* _within_ the lookup and force incremental flushes of the cache */
485
+ /* until enough memory is released for the lookup to succeed. */
486
+ /* */
487
+ /* If a lookup fails with `FT_Err_Out_Of_Memory' the cache has */
488
+ /* already been completely flushed, and still no memory is available */
489
+ /* for the operation. */
490
+ /* */
491
+ FT_EXPORT( FT_Error )
492
+ FTC_Manager_LookupSize( FTC_Manager manager,
493
+ FTC_Scaler scaler,
494
+ FT_Size *asize );
495
+
496
+
497
+ /*************************************************************************/
498
+ /* */
499
+ /* <Function> */
500
+ /* FTC_Node_Unref */
501
+ /* */
502
+ /* <Description> */
503
+ /* Decrement a cache node's internal reference count. When the count */
504
+ /* reaches 0, it is not destroyed but becomes eligible for subsequent */
505
+ /* cache flushes. */
506
+ /* */
507
+ /* <Input> */
508
+ /* node :: The cache node handle. */
509
+ /* */
510
+ /* manager :: The cache manager handle. */
511
+ /* */
512
+ FT_EXPORT( void )
513
+ FTC_Node_Unref( FTC_Node node,
514
+ FTC_Manager manager );
515
+
516
+
517
+ /*************************************************************************
518
+ *
519
+ * @function:
520
+ * FTC_Manager_RemoveFaceID
521
+ *
522
+ * @description:
523
+ * A special function used to indicate to the cache manager that
524
+ * a given @FTC_FaceID is no longer valid, either because its
525
+ * content changed, or because it was deallocated or uninstalled.
526
+ *
527
+ * @input:
528
+ * manager ::
529
+ * The cache manager handle.
530
+ *
531
+ * face_id ::
532
+ * The @FTC_FaceID to be removed.
533
+ *
534
+ * @note:
535
+ * This function flushes all nodes from the cache corresponding to this
536
+ * `face_id', with the exception of nodes with a non-null reference
537
+ * count.
538
+ *
539
+ * Such nodes are however modified internally so as to never appear
540
+ * in later lookups with the same `face_id' value, and to be immediately
541
+ * destroyed when released by all their users.
542
+ *
543
+ */
544
+ FT_EXPORT( void )
545
+ FTC_Manager_RemoveFaceID( FTC_Manager manager,
546
+ FTC_FaceID face_id );
547
+
548
+
549
+ /*************************************************************************/
550
+ /* */
551
+ /* <Section> */
552
+ /* cache_subsystem */
553
+ /* */
554
+ /*************************************************************************/
555
+
556
+ /*************************************************************************
557
+ *
558
+ * @type:
559
+ * FTC_CMapCache
560
+ *
561
+ * @description:
562
+ * An opaque handle used to model a charmap cache. This cache is to
563
+ * hold character codes -> glyph indices mappings.
564
+ *
565
+ */
566
+ typedef struct FTC_CMapCacheRec_* FTC_CMapCache;
567
+
568
+
569
+ /*************************************************************************
570
+ *
571
+ * @function:
572
+ * FTC_CMapCache_New
573
+ *
574
+ * @description:
575
+ * Create a new charmap cache.
576
+ *
577
+ * @input:
578
+ * manager ::
579
+ * A handle to the cache manager.
580
+ *
581
+ * @output:
582
+ * acache ::
583
+ * A new cache handle. NULL in case of error.
584
+ *
585
+ * @return:
586
+ * FreeType error code. 0~means success.
587
+ *
588
+ * @note:
589
+ * Like all other caches, this one will be destroyed with the cache
590
+ * manager.
591
+ *
592
+ */
593
+ FT_EXPORT( FT_Error )
594
+ FTC_CMapCache_New( FTC_Manager manager,
595
+ FTC_CMapCache *acache );
596
+
597
+
598
+ /************************************************************************
599
+ *
600
+ * @function:
601
+ * FTC_CMapCache_Lookup
602
+ *
603
+ * @description:
604
+ * Translate a character code into a glyph index, using the charmap
605
+ * cache.
606
+ *
607
+ * @input:
608
+ * cache ::
609
+ * A charmap cache handle.
610
+ *
611
+ * face_id ::
612
+ * The source face ID.
613
+ *
614
+ * cmap_index ::
615
+ * The index of the charmap in the source face. Any negative value
616
+ * means to use the cache @FT_Face's default charmap.
617
+ *
618
+ * char_code ::
619
+ * The character code (in the corresponding charmap).
620
+ *
621
+ * @return:
622
+ * Glyph index. 0~means `no glyph'.
623
+ *
624
+ */
625
+ FT_EXPORT( FT_UInt )
626
+ FTC_CMapCache_Lookup( FTC_CMapCache cache,
627
+ FTC_FaceID face_id,
628
+ FT_Int cmap_index,
629
+ FT_UInt32 char_code );
630
+
631
+
632
+ /*************************************************************************/
633
+ /* */
634
+ /* <Section> */
635
+ /* cache_subsystem */
636
+ /* */
637
+ /*************************************************************************/
638
+
639
+
640
+ /*************************************************************************/
641
+ /*************************************************************************/
642
+ /*************************************************************************/
643
+ /***** *****/
644
+ /***** IMAGE CACHE OBJECT *****/
645
+ /***** *****/
646
+ /*************************************************************************/
647
+ /*************************************************************************/
648
+ /*************************************************************************/
649
+
650
+
651
+ /*************************************************************************
652
+ *
653
+ * @struct:
654
+ * FTC_ImageTypeRec
655
+ *
656
+ * @description:
657
+ * A structure used to model the type of images in a glyph cache.
658
+ *
659
+ * @fields:
660
+ * face_id ::
661
+ * The face ID.
662
+ *
663
+ * width ::
664
+ * The width in pixels.
665
+ *
666
+ * height ::
667
+ * The height in pixels.
668
+ *
669
+ * flags ::
670
+ * The load flags, as in @FT_Load_Glyph.
671
+ *
672
+ */
673
+ typedef struct FTC_ImageTypeRec_
674
+ {
675
+ FTC_FaceID face_id;
676
+ FT_Int width;
677
+ FT_Int height;
678
+ FT_Int32 flags;
679
+
680
+ } FTC_ImageTypeRec;
681
+
682
+
683
+ /*************************************************************************
684
+ *
685
+ * @type:
686
+ * FTC_ImageType
687
+ *
688
+ * @description:
689
+ * A handle to an @FTC_ImageTypeRec structure.
690
+ *
691
+ */
692
+ typedef struct FTC_ImageTypeRec_* FTC_ImageType;
693
+
694
+
695
+ /* */
696
+
697
+
698
+ #define FTC_IMAGE_TYPE_COMPARE( d1, d2 ) \
699
+ ( (d1)->face_id == (d2)->face_id && \
700
+ (d1)->width == (d2)->width && \
701
+ (d1)->flags == (d2)->flags )
702
+
703
+ #define FTC_IMAGE_TYPE_HASH( d ) \
704
+ (FT_UFast)( FTC_FACE_ID_HASH( (d)->face_id ) ^ \
705
+ ( (d)->width << 8 ) ^ (d)->height ^ \
706
+ ( (d)->flags << 4 ) )
707
+
708
+
709
+ /*************************************************************************/
710
+ /* */
711
+ /* <Type> */
712
+ /* FTC_ImageCache */
713
+ /* */
714
+ /* <Description> */
715
+ /* A handle to an glyph image cache object. They are designed to */
716
+ /* hold many distinct glyph images while not exceeding a certain */
717
+ /* memory threshold. */
718
+ /* */
719
+ typedef struct FTC_ImageCacheRec_* FTC_ImageCache;
720
+
721
+
722
+ /*************************************************************************/
723
+ /* */
724
+ /* <Function> */
725
+ /* FTC_ImageCache_New */
726
+ /* */
727
+ /* <Description> */
728
+ /* Create a new glyph image cache. */
729
+ /* */
730
+ /* <Input> */
731
+ /* manager :: The parent manager for the image cache. */
732
+ /* */
733
+ /* <Output> */
734
+ /* acache :: A handle to the new glyph image cache object. */
735
+ /* */
736
+ /* <Return> */
737
+ /* FreeType error code. 0~means success. */
738
+ /* */
739
+ FT_EXPORT( FT_Error )
740
+ FTC_ImageCache_New( FTC_Manager manager,
741
+ FTC_ImageCache *acache );
742
+
743
+
744
+ /*************************************************************************/
745
+ /* */
746
+ /* <Function> */
747
+ /* FTC_ImageCache_Lookup */
748
+ /* */
749
+ /* <Description> */
750
+ /* Retrieve a given glyph image from a glyph image cache. */
751
+ /* */
752
+ /* <Input> */
753
+ /* cache :: A handle to the source glyph image cache. */
754
+ /* */
755
+ /* type :: A pointer to a glyph image type descriptor. */
756
+ /* */
757
+ /* gindex :: The glyph index to retrieve. */
758
+ /* */
759
+ /* <Output> */
760
+ /* aglyph :: The corresponding @FT_Glyph object. 0~in case of */
761
+ /* failure. */
762
+ /* */
763
+ /* anode :: Used to return the address of of the corresponding cache */
764
+ /* node after incrementing its reference count (see note */
765
+ /* below). */
766
+ /* */
767
+ /* <Return> */
768
+ /* FreeType error code. 0~means success. */
769
+ /* */
770
+ /* <Note> */
771
+ /* The returned glyph is owned and managed by the glyph image cache. */
772
+ /* Never try to transform or discard it manually! You can however */
773
+ /* create a copy with @FT_Glyph_Copy and modify the new one. */
774
+ /* */
775
+ /* If `anode' is _not_ NULL, it receives the address of the cache */
776
+ /* node containing the glyph image, after increasing its reference */
777
+ /* count. This ensures that the node (as well as the @FT_Glyph) will */
778
+ /* always be kept in the cache until you call @FTC_Node_Unref to */
779
+ /* `release' it. */
780
+ /* */
781
+ /* If `anode' is NULL, the cache node is left unchanged, which means */
782
+ /* that the @FT_Glyph could be flushed out of the cache on the next */
783
+ /* call to one of the caching sub-system APIs. Don't assume that it */
784
+ /* is persistent! */
785
+ /* */
786
+ FT_EXPORT( FT_Error )
787
+ FTC_ImageCache_Lookup( FTC_ImageCache cache,
788
+ FTC_ImageType type,
789
+ FT_UInt gindex,
790
+ FT_Glyph *aglyph,
791
+ FTC_Node *anode );
792
+
793
+
794
+ /*************************************************************************/
795
+ /* */
796
+ /* <Function> */
797
+ /* FTC_ImageCache_LookupScaler */
798
+ /* */
799
+ /* <Description> */
800
+ /* A variant of @FTC_ImageCache_Lookup that uses an @FTC_ScalerRec */
801
+ /* to specify the face ID and its size. */
802
+ /* */
803
+ /* <Input> */
804
+ /* cache :: A handle to the source glyph image cache. */
805
+ /* */
806
+ /* scaler :: A pointer to a scaler descriptor. */
807
+ /* */
808
+ /* load_flags :: The corresponding load flags. */
809
+ /* */
810
+ /* gindex :: The glyph index to retrieve. */
811
+ /* */
812
+ /* <Output> */
813
+ /* aglyph :: The corresponding @FT_Glyph object. 0~in case of */
814
+ /* failure. */
815
+ /* */
816
+ /* anode :: Used to return the address of of the corresponding */
817
+ /* cache node after incrementing its reference count */
818
+ /* (see note below). */
819
+ /* */
820
+ /* <Return> */
821
+ /* FreeType error code. 0~means success. */
822
+ /* */
823
+ /* <Note> */
824
+ /* The returned glyph is owned and managed by the glyph image cache. */
825
+ /* Never try to transform or discard it manually! You can however */
826
+ /* create a copy with @FT_Glyph_Copy and modify the new one. */
827
+ /* */
828
+ /* If `anode' is _not_ NULL, it receives the address of the cache */
829
+ /* node containing the glyph image, after increasing its reference */
830
+ /* count. This ensures that the node (as well as the @FT_Glyph) will */
831
+ /* always be kept in the cache until you call @FTC_Node_Unref to */
832
+ /* `release' it. */
833
+ /* */
834
+ /* If `anode' is NULL, the cache node is left unchanged, which means */
835
+ /* that the @FT_Glyph could be flushed out of the cache on the next */
836
+ /* call to one of the caching sub-system APIs. Don't assume that it */
837
+ /* is persistent! */
838
+ /* */
839
+ /* Calls to @FT_Set_Char_Size and friends have no effect on cached */
840
+ /* glyphs; you should always use the FreeType cache API instead. */
841
+ /* */
842
+ FT_EXPORT( FT_Error )
843
+ FTC_ImageCache_LookupScaler( FTC_ImageCache cache,
844
+ FTC_Scaler scaler,
845
+ FT_ULong load_flags,
846
+ FT_UInt gindex,
847
+ FT_Glyph *aglyph,
848
+ FTC_Node *anode );
849
+
850
+
851
+ /*************************************************************************/
852
+ /* */
853
+ /* <Type> */
854
+ /* FTC_SBit */
855
+ /* */
856
+ /* <Description> */
857
+ /* A handle to a small bitmap descriptor. See the @FTC_SBitRec */
858
+ /* structure for details. */
859
+ /* */
860
+ typedef struct FTC_SBitRec_* FTC_SBit;
861
+
862
+
863
+ /*************************************************************************/
864
+ /* */
865
+ /* <Struct> */
866
+ /* FTC_SBitRec */
867
+ /* */
868
+ /* <Description> */
869
+ /* A very compact structure used to describe a small glyph bitmap. */
870
+ /* */
871
+ /* <Fields> */
872
+ /* width :: The bitmap width in pixels. */
873
+ /* */
874
+ /* height :: The bitmap height in pixels. */
875
+ /* */
876
+ /* left :: The horizontal distance from the pen position to the */
877
+ /* left bitmap border (a.k.a. `left side bearing', or */
878
+ /* `lsb'). */
879
+ /* */
880
+ /* top :: The vertical distance from the pen position (on the */
881
+ /* baseline) to the upper bitmap border (a.k.a. `top */
882
+ /* side bearing'). The distance is positive for upwards */
883
+ /* y~coordinates. */
884
+ /* */
885
+ /* format :: The format of the glyph bitmap (monochrome or gray). */
886
+ /* */
887
+ /* max_grays :: Maximum gray level value (in the range 1 to~255). */
888
+ /* */
889
+ /* pitch :: The number of bytes per bitmap line. May be positive */
890
+ /* or negative. */
891
+ /* */
892
+ /* xadvance :: The horizontal advance width in pixels. */
893
+ /* */
894
+ /* yadvance :: The vertical advance height in pixels. */
895
+ /* */
896
+ /* buffer :: A pointer to the bitmap pixels. */
897
+ /* */
898
+ typedef struct FTC_SBitRec_
899
+ {
900
+ FT_Byte width;
901
+ FT_Byte height;
902
+ FT_Char left;
903
+ FT_Char top;
904
+
905
+ FT_Byte format;
906
+ FT_Byte max_grays;
907
+ FT_Short pitch;
908
+ FT_Char xadvance;
909
+ FT_Char yadvance;
910
+
911
+ FT_Byte* buffer;
912
+
913
+ } FTC_SBitRec;
914
+
915
+
916
+ /*************************************************************************/
917
+ /* */
918
+ /* <Type> */
919
+ /* FTC_SBitCache */
920
+ /* */
921
+ /* <Description> */
922
+ /* A handle to a small bitmap cache. These are special cache objects */
923
+ /* used to store small glyph bitmaps (and anti-aliased pixmaps) in a */
924
+ /* much more efficient way than the traditional glyph image cache */
925
+ /* implemented by @FTC_ImageCache. */
926
+ /* */
927
+ typedef struct FTC_SBitCacheRec_* FTC_SBitCache;
928
+
929
+
930
+ /*************************************************************************/
931
+ /* */
932
+ /* <Function> */
933
+ /* FTC_SBitCache_New */
934
+ /* */
935
+ /* <Description> */
936
+ /* Create a new cache to store small glyph bitmaps. */
937
+ /* */
938
+ /* <Input> */
939
+ /* manager :: A handle to the source cache manager. */
940
+ /* */
941
+ /* <Output> */
942
+ /* acache :: A handle to the new sbit cache. NULL in case of error. */
943
+ /* */
944
+ /* <Return> */
945
+ /* FreeType error code. 0~means success. */
946
+ /* */
947
+ FT_EXPORT( FT_Error )
948
+ FTC_SBitCache_New( FTC_Manager manager,
949
+ FTC_SBitCache *acache );
950
+
951
+
952
+ /*************************************************************************/
953
+ /* */
954
+ /* <Function> */
955
+ /* FTC_SBitCache_Lookup */
956
+ /* */
957
+ /* <Description> */
958
+ /* Look up a given small glyph bitmap in a given sbit cache and */
959
+ /* `lock' it to prevent its flushing from the cache until needed. */
960
+ /* */
961
+ /* <Input> */
962
+ /* cache :: A handle to the source sbit cache. */
963
+ /* */
964
+ /* type :: A pointer to the glyph image type descriptor. */
965
+ /* */
966
+ /* gindex :: The glyph index. */
967
+ /* */
968
+ /* <Output> */
969
+ /* sbit :: A handle to a small bitmap descriptor. */
970
+ /* */
971
+ /* anode :: Used to return the address of of the corresponding cache */
972
+ /* node after incrementing its reference count (see note */
973
+ /* below). */
974
+ /* */
975
+ /* <Return> */
976
+ /* FreeType error code. 0~means success. */
977
+ /* */
978
+ /* <Note> */
979
+ /* The small bitmap descriptor and its bit buffer are owned by the */
980
+ /* cache and should never be freed by the application. They might */
981
+ /* as well disappear from memory on the next cache lookup, so don't */
982
+ /* treat them as persistent data. */
983
+ /* */
984
+ /* The descriptor's `buffer' field is set to~0 to indicate a missing */
985
+ /* glyph bitmap. */
986
+ /* */
987
+ /* If `anode' is _not_ NULL, it receives the address of the cache */
988
+ /* node containing the bitmap, after increasing its reference count. */
989
+ /* This ensures that the node (as well as the image) will always be */
990
+ /* kept in the cache until you call @FTC_Node_Unref to `release' it. */
991
+ /* */
992
+ /* If `anode' is NULL, the cache node is left unchanged, which means */
993
+ /* that the bitmap could be flushed out of the cache on the next */
994
+ /* call to one of the caching sub-system APIs. Don't assume that it */
995
+ /* is persistent! */
996
+ /* */
997
+ FT_EXPORT( FT_Error )
998
+ FTC_SBitCache_Lookup( FTC_SBitCache cache,
999
+ FTC_ImageType type,
1000
+ FT_UInt gindex,
1001
+ FTC_SBit *sbit,
1002
+ FTC_Node *anode );
1003
+
1004
+
1005
+ /*************************************************************************/
1006
+ /* */
1007
+ /* <Function> */
1008
+ /* FTC_SBitCache_LookupScaler */
1009
+ /* */
1010
+ /* <Description> */
1011
+ /* A variant of @FTC_SBitCache_Lookup that uses an @FTC_ScalerRec */
1012
+ /* to specify the face ID and its size. */
1013
+ /* */
1014
+ /* <Input> */
1015
+ /* cache :: A handle to the source sbit cache. */
1016
+ /* */
1017
+ /* scaler :: A pointer to the scaler descriptor. */
1018
+ /* */
1019
+ /* load_flags :: The corresponding load flags. */
1020
+ /* */
1021
+ /* gindex :: The glyph index. */
1022
+ /* */
1023
+ /* <Output> */
1024
+ /* sbit :: A handle to a small bitmap descriptor. */
1025
+ /* */
1026
+ /* anode :: Used to return the address of of the corresponding */
1027
+ /* cache node after incrementing its reference count */
1028
+ /* (see note below). */
1029
+ /* */
1030
+ /* <Return> */
1031
+ /* FreeType error code. 0~means success. */
1032
+ /* */
1033
+ /* <Note> */
1034
+ /* The small bitmap descriptor and its bit buffer are owned by the */
1035
+ /* cache and should never be freed by the application. They might */
1036
+ /* as well disappear from memory on the next cache lookup, so don't */
1037
+ /* treat them as persistent data. */
1038
+ /* */
1039
+ /* The descriptor's `buffer' field is set to~0 to indicate a missing */
1040
+ /* glyph bitmap. */
1041
+ /* */
1042
+ /* If `anode' is _not_ NULL, it receives the address of the cache */
1043
+ /* node containing the bitmap, after increasing its reference count. */
1044
+ /* This ensures that the node (as well as the image) will always be */
1045
+ /* kept in the cache until you call @FTC_Node_Unref to `release' it. */
1046
+ /* */
1047
+ /* If `anode' is NULL, the cache node is left unchanged, which means */
1048
+ /* that the bitmap could be flushed out of the cache on the next */
1049
+ /* call to one of the caching sub-system APIs. Don't assume that it */
1050
+ /* is persistent! */
1051
+ /* */
1052
+ FT_EXPORT( FT_Error )
1053
+ FTC_SBitCache_LookupScaler( FTC_SBitCache cache,
1054
+ FTC_Scaler scaler,
1055
+ FT_ULong load_flags,
1056
+ FT_UInt gindex,
1057
+ FTC_SBit *sbit,
1058
+ FTC_Node *anode );
1059
+
1060
+
1061
+ /* */
1062
+
1063
+ #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
1064
+
1065
+ /*@***********************************************************************/
1066
+ /* */
1067
+ /* <Struct> */
1068
+ /* FTC_FontRec */
1069
+ /* */
1070
+ /* <Description> */
1071
+ /* A simple structure used to describe a given `font' to the cache */
1072
+ /* manager. Note that a `font' is the combination of a given face */
1073
+ /* with a given character size. */
1074
+ /* */
1075
+ /* <Fields> */
1076
+ /* face_id :: The ID of the face to use. */
1077
+ /* */
1078
+ /* pix_width :: The character width in integer pixels. */
1079
+ /* */
1080
+ /* pix_height :: The character height in integer pixels. */
1081
+ /* */
1082
+ typedef struct FTC_FontRec_
1083
+ {
1084
+ FTC_FaceID face_id;
1085
+ FT_UShort pix_width;
1086
+ FT_UShort pix_height;
1087
+
1088
+ } FTC_FontRec;
1089
+
1090
+
1091
+ /* */
1092
+
1093
+
1094
+ #define FTC_FONT_COMPARE( f1, f2 ) \
1095
+ ( (f1)->face_id == (f2)->face_id && \
1096
+ (f1)->pix_width == (f2)->pix_width && \
1097
+ (f1)->pix_height == (f2)->pix_height )
1098
+
1099
+ #define FTC_FONT_HASH( f ) \
1100
+ (FT_UInt32)( FTC_FACE_ID_HASH((f)->face_id) ^ \
1101
+ ((f)->pix_width << 8) ^ \
1102
+ ((f)->pix_height) )
1103
+
1104
+ typedef FTC_FontRec* FTC_Font;
1105
+
1106
+
1107
+ FT_EXPORT( FT_Error )
1108
+ FTC_Manager_Lookup_Face( FTC_Manager manager,
1109
+ FTC_FaceID face_id,
1110
+ FT_Face *aface );
1111
+
1112
+ FT_EXPORT( FT_Error )
1113
+ FTC_Manager_Lookup_Size( FTC_Manager manager,
1114
+ FTC_Font font,
1115
+ FT_Face *aface,
1116
+ FT_Size *asize );
1117
+
1118
+ #endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
1119
+
1120
+
1121
+ /* */
1122
+
1123
+ FT_END_HEADER
1124
+
1125
+ #endif /* __FTCACHE_H__ */
1126
+
1127
+
1128
+ /* END */