pdf2json 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.markdown +9 -0
- data/bin/.gitkeep +0 -0
- data/ext/extconf.rb +30 -0
- data/lib/pdf2json.rb +8 -0
- data/pdf2json-0.52-source/AUTHORS +24 -0
- data/pdf2json-0.52-source/CHANGES +11 -0
- data/pdf2json-0.52-source/Makefile +84 -0
- data/pdf2json-0.52-source/Makefile.in +84 -0
- data/pdf2json-0.52-source/aclocal.m4 +274 -0
- data/pdf2json-0.52-source/aconf-win32.h +86 -0
- data/pdf2json-0.52-source/aconf.h +42 -0
- data/pdf2json-0.52-source/aconf.h.in +41 -0
- data/pdf2json-0.52-source/autom4te.cache/output.0 +6908 -0
- data/pdf2json-0.52-source/autom4te.cache/requests +76 -0
- data/pdf2json-0.52-source/autom4te.cache/traces.0 +466 -0
- data/pdf2json-0.52-source/config.log +1259 -0
- data/pdf2json-0.52-source/config.status +1050 -0
- data/pdf2json-0.52-source/configure +6908 -0
- data/pdf2json-0.52-source/configure.ac +93 -0
- data/pdf2json-0.52-source/doc/pdffonts.1 +130 -0
- data/pdf2json-0.52-source/doc/pdffonts.cat +107 -0
- data/pdf2json-0.52-source/doc/pdffonts.hlp +117 -0
- data/pdf2json-0.52-source/doc/pdfimages.1 +102 -0
- data/pdf2json-0.52-source/doc/pdfimages.cat +92 -0
- data/pdf2json-0.52-source/doc/pdfimages.hlp +101 -0
- data/pdf2json-0.52-source/doc/pdfinfo.1 +158 -0
- data/pdf2json-0.52-source/doc/pdfinfo.cat +119 -0
- data/pdf2json-0.52-source/doc/pdfinfo.hlp +129 -0
- data/pdf2json-0.52-source/doc/pdftoppm.1 +115 -0
- data/pdf2json-0.52-source/doc/pdftoppm.cat +105 -0
- data/pdf2json-0.52-source/doc/pdftoppm.hlp +114 -0
- data/pdf2json-0.52-source/doc/pdftops.1 +229 -0
- data/pdf2json-0.52-source/doc/pdftops.cat +221 -0
- data/pdf2json-0.52-source/doc/pdftops.hlp +231 -0
- data/pdf2json-0.52-source/doc/pdftotext.1 +137 -0
- data/pdf2json-0.52-source/doc/pdftotext.cat +120 -0
- data/pdf2json-0.52-source/doc/pdftotext.hlp +133 -0
- data/pdf2json-0.52-source/doc/sample-xpdfrc +91 -0
- data/pdf2json-0.52-source/doc/xpdf.1 +513 -0
- data/pdf2json-0.52-source/doc/xpdf.cat +476 -0
- data/pdf2json-0.52-source/doc/xpdf.hlp +489 -0
- data/pdf2json-0.52-source/doc/xpdfrc.5 +480 -0
- data/pdf2json-0.52-source/doc/xpdfrc.cat +474 -0
- data/pdf2json-0.52-source/doc/xpdfrc.hlp +479 -0
- data/pdf2json-0.52-source/fofi/.DS_Store +0 -0
- data/pdf2json-0.52-source/fofi/FoFiBase.cc +156 -0
- data/pdf2json-0.52-source/fofi/FoFiBase.h +57 -0
- data/pdf2json-0.52-source/fofi/FoFiBase.o +0 -0
- data/pdf2json-0.52-source/fofi/FoFiEncodings.cc +994 -0
- data/pdf2json-0.52-source/fofi/FoFiEncodings.h +36 -0
- data/pdf2json-0.52-source/fofi/FoFiEncodings.o +0 -0
- data/pdf2json-0.52-source/fofi/FoFiTrueType.cc +2027 -0
- data/pdf2json-0.52-source/fofi/FoFiTrueType.h +174 -0
- data/pdf2json-0.52-source/fofi/FoFiTrueType.o +0 -0
- data/pdf2json-0.52-source/fofi/FoFiType1.cc +252 -0
- data/pdf2json-0.52-source/fofi/FoFiType1.h +59 -0
- data/pdf2json-0.52-source/fofi/FoFiType1.o +0 -0
- data/pdf2json-0.52-source/fofi/FoFiType1C.cc +2603 -0
- data/pdf2json-0.52-source/fofi/FoFiType1C.h +233 -0
- data/pdf2json-0.52-source/fofi/FoFiType1C.o +0 -0
- data/pdf2json-0.52-source/fofi/Makefile +70 -0
- data/pdf2json-0.52-source/fofi/Makefile.dep +0 -0
- data/pdf2json-0.52-source/fofi/Makefile.in +70 -0
- data/pdf2json-0.52-source/fofi/libfofi.a +0 -0
- data/pdf2json-0.52-source/fofi/vms_make.com +0 -0
- data/pdf2json-0.52-source/freetype.win32/.DS_Store +0 -0
- data/pdf2json-0.52-source/freetype.win32/include/.DS_Store +0 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftconfig.h +528 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftheader.h +780 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftmodule.h +32 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftoption.h +733 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/config/ftstdlib.h +173 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/freetype.h +3919 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftadvanc.h +179 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftbbox.h +94 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftbdf.h +209 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftbitmap.h +227 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftcache.h +1128 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftchapters.h +103 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftcid.h +166 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/fterrdef.h +244 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/fterrors.h +206 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftgasp.h +120 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftglyph.h +613 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftgxval.h +358 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftgzip.h +102 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftimage.h +1313 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftincrem.h +353 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftlcdfil.h +213 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftlist.h +277 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftlzw.h +99 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmac.h +274 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmm.h +378 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmodapi.h +483 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftmoderr.h +155 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftotval.h +203 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftoutln.h +537 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftpfr.h +172 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftrender.h +230 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsizes.h +159 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsnames.h +200 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftstroke.h +716 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsynth.h +80 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftsystem.h +347 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/fttrigon.h +350 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/fttypes.h +588 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftwinfnt.h +274 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ftxf86.h +83 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/autohint.h +231 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftcalc.h +179 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftdebug.h +250 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftdriver.h +422 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftgloadr.h +168 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftmemory.h +380 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftobjs.h +1428 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftpic.h +67 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftrfork.h +196 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftserv.h +620 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftstream.h +539 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/fttrace.h +139 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/ftvalid.h +150 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/internal.h +51 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/pcftypes.h +56 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/psaux.h +873 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/pshints.h +712 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svbdf.h +77 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svcid.h +83 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svgldict.h +82 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svgxval.h +72 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svkern.h +51 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svmm.h +104 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svotval.h +55 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpfr.h +66 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpostnm.h +79 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpscmap.h +164 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svpsinfo.h +92 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svsfnt.h +102 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svttcmap.h +106 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svtteng.h +53 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svttglyf.h +67 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svwinfnt.h +50 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/services/svxf86nm.h +55 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/sfnt.h +897 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/t1types.h +270 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/internal/tttypes.h +1543 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/t1tables.h +504 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ttnameid.h +1247 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/tttables.h +759 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/tttags.h +107 -0
- data/pdf2json-0.52-source/freetype.win32/include/freetype/ttunpat.h +59 -0
- data/pdf2json-0.52-source/freetype.win32/include/ft2build.h +39 -0
- data/pdf2json-0.52-source/freetype.win32/lib/freetype_a.lib +0 -0
- data/pdf2json-0.52-source/goo/.DS_Store +0 -0
- data/pdf2json-0.52-source/goo/FixedPoint.cc +118 -0
- data/pdf2json-0.52-source/goo/FixedPoint.h +155 -0
- data/pdf2json-0.52-source/goo/FixedPoint.o +0 -0
- data/pdf2json-0.52-source/goo/GHash.cc +380 -0
- data/pdf2json-0.52-source/goo/GHash.h +78 -0
- data/pdf2json-0.52-source/goo/GHash.o +0 -0
- data/pdf2json-0.52-source/goo/GList.cc +97 -0
- data/pdf2json-0.52-source/goo/GList.h +96 -0
- data/pdf2json-0.52-source/goo/GList.o +0 -0
- data/pdf2json-0.52-source/goo/GMutex.h +49 -0
- data/pdf2json-0.52-source/goo/GString.cc +724 -0
- data/pdf2json-0.52-source/goo/GString.cc.fixed +718 -0
- data/pdf2json-0.52-source/goo/GString.h +136 -0
- data/pdf2json-0.52-source/goo/GString.o +0 -0
- data/pdf2json-0.52-source/goo/ImgWriter.o +0 -0
- data/pdf2json-0.52-source/goo/JpegWriter.o +0 -0
- data/pdf2json-0.52-source/goo/Makefile +72 -0
- data/pdf2json-0.52-source/goo/Makefile.dep +0 -0
- data/pdf2json-0.52-source/goo/Makefile.in +72 -0
- data/pdf2json-0.52-source/goo/PNGWriter.o +0 -0
- data/pdf2json-0.52-source/goo/gfile.cc +731 -0
- data/pdf2json-0.52-source/goo/gfile.h +138 -0
- data/pdf2json-0.52-source/goo/gfile.o +0 -0
- data/pdf2json-0.52-source/goo/gmem.cc +264 -0
- data/pdf2json-0.52-source/goo/gmem.h +79 -0
- data/pdf2json-0.52-source/goo/gmem.o +0 -0
- data/pdf2json-0.52-source/goo/gmempp.cc +32 -0
- data/pdf2json-0.52-source/goo/gmempp.o +0 -0
- data/pdf2json-0.52-source/goo/gtypes.h +29 -0
- data/pdf2json-0.52-source/goo/libGoo.a +0 -0
- data/pdf2json-0.52-source/goo/parseargs.c +190 -0
- data/pdf2json-0.52-source/goo/parseargs.h +71 -0
- data/pdf2json-0.52-source/goo/parseargs.o +0 -0
- data/pdf2json-0.52-source/goo/vms_directory.c +214 -0
- data/pdf2json-0.52-source/goo/vms_dirent.h +67 -0
- data/pdf2json-0.52-source/goo/vms_make.com +82 -0
- data/pdf2json-0.52-source/goo/vms_sys_dirent.h +54 -0
- data/pdf2json-0.52-source/goo/vms_unix_time.h +102 -0
- data/pdf2json-0.52-source/goo/vms_unix_times.c +42 -0
- data/pdf2json-0.52-source/goo/vms_unlink.c +22 -0
- data/pdf2json-0.52-source/ms_make.bat +199 -0
- data/pdf2json-0.52-source/splash/.DS_Store +0 -0
- data/pdf2json-0.52-source/splash/Makefile +103 -0
- data/pdf2json-0.52-source/splash/Makefile.dep +0 -0
- data/pdf2json-0.52-source/splash/Makefile.in +103 -0
- data/pdf2json-0.52-source/splash/Splash.cc +3310 -0
- data/pdf2json-0.52-source/splash/Splash.h +293 -0
- data/pdf2json-0.52-source/splash/Splash.o +0 -0
- data/pdf2json-0.52-source/splash/SplashBitmap.cc +188 -0
- data/pdf2json-0.52-source/splash/SplashBitmap.h +64 -0
- data/pdf2json-0.52-source/splash/SplashBitmap.o +0 -0
- data/pdf2json-0.52-source/splash/SplashClip.cc +382 -0
- data/pdf2json-0.52-source/splash/SplashClip.h +107 -0
- data/pdf2json-0.52-source/splash/SplashClip.o +0 -0
- data/pdf2json-0.52-source/splash/SplashErrorCodes.h +32 -0
- data/pdf2json-0.52-source/splash/SplashFTFont.cc +357 -0
- data/pdf2json-0.52-source/splash/SplashFTFont.h +58 -0
- data/pdf2json-0.52-source/splash/SplashFTFont.o +0 -0
- data/pdf2json-0.52-source/splash/SplashFTFontEngine.cc +179 -0
- data/pdf2json-0.52-source/splash/SplashFTFontEngine.h +65 -0
- data/pdf2json-0.52-source/splash/SplashFTFontEngine.o +0 -0
- data/pdf2json-0.52-source/splash/SplashFTFontFile.cc +114 -0
- data/pdf2json-0.52-source/splash/SplashFTFontFile.h +73 -0
- data/pdf2json-0.52-source/splash/SplashFTFontFile.o +0 -0
- data/pdf2json-0.52-source/splash/SplashFont.cc +176 -0
- data/pdf2json-0.52-source/splash/SplashFont.h +104 -0
- data/pdf2json-0.52-source/splash/SplashFont.o +0 -0
- data/pdf2json-0.52-source/splash/SplashFontEngine.cc +317 -0
- data/pdf2json-0.52-source/splash/SplashFontEngine.h +91 -0
- data/pdf2json-0.52-source/splash/SplashFontEngine.o +0 -0
- data/pdf2json-0.52-source/splash/SplashFontFile.cc +55 -0
- data/pdf2json-0.52-source/splash/SplashFontFile.h +60 -0
- data/pdf2json-0.52-source/splash/SplashFontFile.o +0 -0
- data/pdf2json-0.52-source/splash/SplashFontFileID.cc +23 -0
- data/pdf2json-0.52-source/splash/SplashFontFileID.h +30 -0
- data/pdf2json-0.52-source/splash/SplashFontFileID.o +0 -0
- data/pdf2json-0.52-source/splash/SplashGlyphBitmap.h +26 -0
- data/pdf2json-0.52-source/splash/SplashMath.h +89 -0
- data/pdf2json-0.52-source/splash/SplashPath.cc +184 -0
- data/pdf2json-0.52-source/splash/SplashPath.h +121 -0
- data/pdf2json-0.52-source/splash/SplashPath.o +0 -0
- data/pdf2json-0.52-source/splash/SplashPattern.cc +40 -0
- data/pdf2json-0.52-source/splash/SplashPattern.h +65 -0
- data/pdf2json-0.52-source/splash/SplashPattern.o +0 -0
- data/pdf2json-0.52-source/splash/SplashScreen.cc +383 -0
- data/pdf2json-0.52-source/splash/SplashScreen.h +56 -0
- data/pdf2json-0.52-source/splash/SplashScreen.o +0 -0
- data/pdf2json-0.52-source/splash/SplashState.cc +165 -0
- data/pdf2json-0.52-source/splash/SplashState.h +103 -0
- data/pdf2json-0.52-source/splash/SplashState.o +0 -0
- data/pdf2json-0.52-source/splash/SplashT1Font.cc +287 -0
- data/pdf2json-0.52-source/splash/SplashT1Font.h +57 -0
- data/pdf2json-0.52-source/splash/SplashT1Font.o +0 -0
- data/pdf2json-0.52-source/splash/SplashT1FontEngine.cc +124 -0
- data/pdf2json-0.52-source/splash/SplashT1FontEngine.h +53 -0
- data/pdf2json-0.52-source/splash/SplashT1FontEngine.o +0 -0
- data/pdf2json-0.52-source/splash/SplashT1FontFile.cc +97 -0
- data/pdf2json-0.52-source/splash/SplashT1FontFile.h +58 -0
- data/pdf2json-0.52-source/splash/SplashT1FontFile.o +0 -0
- data/pdf2json-0.52-source/splash/SplashTypes.h +132 -0
- data/pdf2json-0.52-source/splash/SplashXPath.cc +438 -0
- data/pdf2json-0.52-source/splash/SplashXPath.h +100 -0
- data/pdf2json-0.52-source/splash/SplashXPath.o +0 -0
- data/pdf2json-0.52-source/splash/SplashXPathScanner.cc +428 -0
- data/pdf2json-0.52-source/splash/SplashXPathScanner.h +87 -0
- data/pdf2json-0.52-source/splash/SplashXPathScanner.o +0 -0
- data/pdf2json-0.52-source/splash/libsplash.a +0 -0
- data/pdf2json-0.52-source/splash/vms_make.com +0 -0
- data/pdf2json-0.52-source/src/.DS_Store +0 -0
- data/pdf2json-0.52-source/src/GVector.h +101 -0
- data/pdf2json-0.52-source/src/ImgOutputDev.cc +1243 -0
- data/pdf2json-0.52-source/src/ImgOutputDev.h +307 -0
- data/pdf2json-0.52-source/src/ImgOutputDev.o +0 -0
- data/pdf2json-0.52-source/src/Makefile +68 -0
- data/pdf2json-0.52-source/src/Makefile.in +68 -0
- data/pdf2json-0.52-source/src/XmlFonts.cc +367 -0
- data/pdf2json-0.52-source/src/XmlFonts.h +91 -0
- data/pdf2json-0.52-source/src/XmlFonts.o +0 -0
- data/pdf2json-0.52-source/src/XmlLinks.cc +101 -0
- data/pdf2json-0.52-source/src/XmlLinks.h +54 -0
- data/pdf2json-0.52-source/src/XmlLinks.o +0 -0
- data/pdf2json-0.52-source/src/pdf2json +0 -0
- data/pdf2json-0.52-source/src/pdf2json.cc +343 -0
- data/pdf2json-0.52-source/src/pdf2json.o +0 -0
- data/pdf2json-0.52-source/src/pdf2xml.dtd +22 -0
- data/pdf2json-0.52-source/src/pdf2xmljson.dtd +9 -0
- data/pdf2json-0.52-source/xpdf/.DS_Store +0 -0
- data/pdf2json-0.52-source/xpdf/Annot.cc +1556 -0
- data/pdf2json-0.52-source/xpdf/Annot.h +142 -0
- data/pdf2json-0.52-source/xpdf/Annot.o +0 -0
- data/pdf2json-0.52-source/xpdf/Array.cc +73 -0
- data/pdf2json-0.52-source/xpdf/Array.h +58 -0
- data/pdf2json-0.52-source/xpdf/Array.o +0 -0
- data/pdf2json-0.52-source/xpdf/BuiltinFont.cc +65 -0
- data/pdf2json-0.52-source/xpdf/BuiltinFont.h +57 -0
- data/pdf2json-0.52-source/xpdf/BuiltinFont.o +0 -0
- data/pdf2json-0.52-source/xpdf/BuiltinFontTables.cc +4284 -0
- data/pdf2json-0.52-source/xpdf/BuiltinFontTables.h +23 -0
- data/pdf2json-0.52-source/xpdf/BuiltinFontTables.o +0 -0
- data/pdf2json-0.52-source/xpdf/CMap.cc +408 -0
- data/pdf2json-0.52-source/xpdf/CMap.h +102 -0
- data/pdf2json-0.52-source/xpdf/CMap.o +0 -0
- data/pdf2json-0.52-source/xpdf/Catalog.cc +374 -0
- data/pdf2json-0.52-source/xpdf/Catalog.h +97 -0
- data/pdf2json-0.52-source/xpdf/Catalog.o +0 -0
- data/pdf2json-0.52-source/xpdf/CharCodeToUnicode.cc +540 -0
- data/pdf2json-0.52-source/xpdf/CharCodeToUnicode.h +117 -0
- data/pdf2json-0.52-source/xpdf/CharCodeToUnicode.o +0 -0
- data/pdf2json-0.52-source/xpdf/CharTypes.h +24 -0
- data/pdf2json-0.52-source/xpdf/CompactFontTables.h +464 -0
- data/pdf2json-0.52-source/xpdf/CoreOutputDev.cc +61 -0
- data/pdf2json-0.52-source/xpdf/CoreOutputDev.h +61 -0
- data/pdf2json-0.52-source/xpdf/Decrypt.cc +776 -0
- data/pdf2json-0.52-source/xpdf/Decrypt.h +95 -0
- data/pdf2json-0.52-source/xpdf/Decrypt.o +0 -0
- data/pdf2json-0.52-source/xpdf/Dict.cc +95 -0
- data/pdf2json-0.52-source/xpdf/Dict.h +77 -0
- data/pdf2json-0.52-source/xpdf/Dict.o +0 -0
- data/pdf2json-0.52-source/xpdf/Error.cc +38 -0
- data/pdf2json-0.52-source/xpdf/Error.h +23 -0
- data/pdf2json-0.52-source/xpdf/Error.o +0 -0
- data/pdf2json-0.52-source/xpdf/ErrorCodes.h +36 -0
- data/pdf2json-0.52-source/xpdf/FontEncodingTables.cc +1824 -0
- data/pdf2json-0.52-source/xpdf/FontEncodingTables.h +20 -0
- data/pdf2json-0.52-source/xpdf/FontEncodingTables.o +0 -0
- data/pdf2json-0.52-source/xpdf/Function.cc +1573 -0
- data/pdf2json-0.52-source/xpdf/Function.h +229 -0
- data/pdf2json-0.52-source/xpdf/Function.o +0 -0
- data/pdf2json-0.52-source/xpdf/Gfx.cc +4187 -0
- data/pdf2json-0.52-source/xpdf/Gfx.h +312 -0
- data/pdf2json-0.52-source/xpdf/Gfx.o +0 -0
- data/pdf2json-0.52-source/xpdf/GfxFont.cc +1568 -0
- data/pdf2json-0.52-source/xpdf/GfxFont.h +320 -0
- data/pdf2json-0.52-source/xpdf/GfxFont.o +0 -0
- data/pdf2json-0.52-source/xpdf/GfxState.cc +4137 -0
- data/pdf2json-0.52-source/xpdf/GfxState.h +1244 -0
- data/pdf2json-0.52-source/xpdf/GfxState.o +0 -0
- data/pdf2json-0.52-source/xpdf/GlobalParams.cc +2924 -0
- data/pdf2json-0.52-source/xpdf/GlobalParams.cc.old +2908 -0
- data/pdf2json-0.52-source/xpdf/GlobalParams.h +466 -0
- data/pdf2json-0.52-source/xpdf/GlobalParams.h.old +463 -0
- data/pdf2json-0.52-source/xpdf/GlobalParams.o +0 -0
- data/pdf2json-0.52-source/xpdf/ImageOutputDev.cc +195 -0
- data/pdf2json-0.52-source/xpdf/ImageOutputDev.h +76 -0
- data/pdf2json-0.52-source/xpdf/ImageOutputDev.o +0 -0
- data/pdf2json-0.52-source/xpdf/JArithmeticDecoder.cc +322 -0
- data/pdf2json-0.52-source/xpdf/JArithmeticDecoder.h +109 -0
- data/pdf2json-0.52-source/xpdf/JArithmeticDecoder.o +0 -0
- data/pdf2json-0.52-source/xpdf/JBIG2Stream.cc +3413 -0
- data/pdf2json-0.52-source/xpdf/JBIG2Stream.h +145 -0
- data/pdf2json-0.52-source/xpdf/JBIG2Stream.o +0 -0
- data/pdf2json-0.52-source/xpdf/JPXStream.cc +3144 -0
- data/pdf2json-0.52-source/xpdf/JPXStream.h +351 -0
- data/pdf2json-0.52-source/xpdf/JPXStream.o +0 -0
- data/pdf2json-0.52-source/xpdf/Lexer.cc +485 -0
- data/pdf2json-0.52-source/xpdf/Lexer.h +80 -0
- data/pdf2json-0.52-source/xpdf/Lexer.o +0 -0
- data/pdf2json-0.52-source/xpdf/Link.cc +806 -0
- data/pdf2json-0.52-source/xpdf/Link.cc.old +784 -0
- data/pdf2json-0.52-source/xpdf/Link.h +415 -0
- data/pdf2json-0.52-source/xpdf/Link.h.old +369 -0
- data/pdf2json-0.52-source/xpdf/Link.o +0 -0
- data/pdf2json-0.52-source/xpdf/Makefile +232 -0
- data/pdf2json-0.52-source/xpdf/Makefile.dep +0 -0
- data/pdf2json-0.52-source/xpdf/Makefile.in +232 -0
- data/pdf2json-0.52-source/xpdf/NameToCharCode.cc +116 -0
- data/pdf2json-0.52-source/xpdf/NameToCharCode.h +42 -0
- data/pdf2json-0.52-source/xpdf/NameToCharCode.o +0 -0
- data/pdf2json-0.52-source/xpdf/NameToUnicodeTable.h +1097 -0
- data/pdf2json-0.52-source/xpdf/Object.cc +231 -0
- data/pdf2json-0.52-source/xpdf/Object.h +303 -0
- data/pdf2json-0.52-source/xpdf/Object.o +0 -0
- data/pdf2json-0.52-source/xpdf/Outline.cc +151 -0
- data/pdf2json-0.52-source/xpdf/Outline.h +76 -0
- data/pdf2json-0.52-source/xpdf/Outline.o +0 -0
- data/pdf2json-0.52-source/xpdf/OutputDev.cc +131 -0
- data/pdf2json-0.52-source/xpdf/OutputDev.h +253 -0
- data/pdf2json-0.52-source/xpdf/OutputDev.o +0 -0
- data/pdf2json-0.52-source/xpdf/PDFCore.cc +2044 -0
- data/pdf2json-0.52-source/xpdf/PDFCore.h +321 -0
- data/pdf2json-0.52-source/xpdf/PDFDoc.cc +404 -0
- data/pdf2json-0.52-source/xpdf/PDFDoc.h +183 -0
- data/pdf2json-0.52-source/xpdf/PDFDoc.o +0 -0
- data/pdf2json-0.52-source/xpdf/PDFDocEncoding.cc +44 -0
- data/pdf2json-0.52-source/xpdf/PDFDocEncoding.h +16 -0
- data/pdf2json-0.52-source/xpdf/PDFDocEncoding.o +0 -0
- data/pdf2json-0.52-source/xpdf/PSOutputDev.cc +6224 -0
- data/pdf2json-0.52-source/xpdf/PSOutputDev.h +395 -0
- data/pdf2json-0.52-source/xpdf/PSOutputDev.o +0 -0
- data/pdf2json-0.52-source/xpdf/PSTokenizer.cc +135 -0
- data/pdf2json-0.52-source/xpdf/PSTokenizer.h +41 -0
- data/pdf2json-0.52-source/xpdf/PSTokenizer.o +0 -0
- data/pdf2json-0.52-source/xpdf/Page.cc +454 -0
- data/pdf2json-0.52-source/xpdf/Page.h +187 -0
- data/pdf2json-0.52-source/xpdf/Page.o +0 -0
- data/pdf2json-0.52-source/xpdf/Parser.cc +227 -0
- data/pdf2json-0.52-source/xpdf/Parser.h +59 -0
- data/pdf2json-0.52-source/xpdf/Parser.o +0 -0
- data/pdf2json-0.52-source/xpdf/PreScanOutputDev.cc +257 -0
- data/pdf2json-0.52-source/xpdf/PreScanOutputDev.h +130 -0
- data/pdf2json-0.52-source/xpdf/PreScanOutputDev.o +0 -0
- data/pdf2json-0.52-source/xpdf/SecurityHandler.cc +390 -0
- data/pdf2json-0.52-source/xpdf/SecurityHandler.h +160 -0
- data/pdf2json-0.52-source/xpdf/SecurityHandler.o +0 -0
- data/pdf2json-0.52-source/xpdf/SplashOutputDev.cc +2845 -0
- data/pdf2json-0.52-source/xpdf/SplashOutputDev.h +247 -0
- data/pdf2json-0.52-source/xpdf/SplashOutputDev.o +0 -0
- data/pdf2json-0.52-source/xpdf/Stream-CCITT.h +459 -0
- data/pdf2json-0.52-source/xpdf/Stream.cc +4627 -0
- data/pdf2json-0.52-source/xpdf/Stream.h +858 -0
- data/pdf2json-0.52-source/xpdf/Stream.o +0 -0
- data/pdf2json-0.52-source/xpdf/TextOutputDev.cc +4090 -0
- data/pdf2json-0.52-source/xpdf/TextOutputDev.h +661 -0
- data/pdf2json-0.52-source/xpdf/TextOutputDev.o +0 -0
- data/pdf2json-0.52-source/xpdf/UTF8.h +56 -0
- data/pdf2json-0.52-source/xpdf/UnicodeMap.cc +302 -0
- data/pdf2json-0.52-source/xpdf/UnicodeMap.cc.old +293 -0
- data/pdf2json-0.52-source/xpdf/UnicodeMap.h +135 -0
- data/pdf2json-0.52-source/xpdf/UnicodeMap.h.old +123 -0
- data/pdf2json-0.52-source/xpdf/UnicodeMap.o +0 -0
- data/pdf2json-0.52-source/xpdf/UnicodeMapTables.h +361 -0
- data/pdf2json-0.52-source/xpdf/UnicodeTypeTable.cc +949 -0
- data/pdf2json-0.52-source/xpdf/UnicodeTypeTable.h +20 -0
- data/pdf2json-0.52-source/xpdf/UnicodeTypeTable.o +0 -0
- data/pdf2json-0.52-source/xpdf/XPDFApp.cc +447 -0
- data/pdf2json-0.52-source/xpdf/XPDFApp.h +114 -0
- data/pdf2json-0.52-source/xpdf/XPDFCore.cc +1655 -0
- data/pdf2json-0.52-source/xpdf/XPDFCore.h +251 -0
- data/pdf2json-0.52-source/xpdf/XPDFTree.cc +931 -0
- data/pdf2json-0.52-source/xpdf/XPDFTree.h +45 -0
- data/pdf2json-0.52-source/xpdf/XPDFTreeP.h +87 -0
- data/pdf2json-0.52-source/xpdf/XPDFViewer.cc +3488 -0
- data/pdf2json-0.52-source/xpdf/XPDFViewer.h +352 -0
- data/pdf2json-0.52-source/xpdf/XRef.cc +896 -0
- data/pdf2json-0.52-source/xpdf/XRef.h +133 -0
- data/pdf2json-0.52-source/xpdf/XRef.o +0 -0
- data/pdf2json-0.52-source/xpdf/XpdfPluginAPI.cc +262 -0
- data/pdf2json-0.52-source/xpdf/XpdfPluginAPI.h +341 -0
- data/pdf2json-0.52-source/xpdf/XpdfPluginAPI.o +0 -0
- data/pdf2json-0.52-source/xpdf/about-text.h +48 -0
- data/pdf2json-0.52-source/xpdf/about.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/backArrow.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/backArrowDis.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/config.h +112 -0
- data/pdf2json-0.52-source/xpdf/dblLeftArrow.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/dblLeftArrowDis.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/dblRightArrow.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/dblRightArrowDis.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/find.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/findDis.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/forwardArrow.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/forwardArrowDis.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/leftArrow.xbm +5 -0
- data/pdf2json-0.52-source/xpdf/leftArrowDis.xbm +5 -0
- data/pdf2json-0.52-source/xpdf/libXpdf.a +0 -0
- data/pdf2json-0.52-source/xpdf/pdffonts +0 -0
- data/pdf2json-0.52-source/xpdf/pdffonts.cc +298 -0
- data/pdf2json-0.52-source/xpdf/pdffonts.o +0 -0
- data/pdf2json-0.52-source/xpdf/pdfimages +0 -0
- data/pdf2json-0.52-source/xpdf/pdfimages.cc +155 -0
- data/pdf2json-0.52-source/xpdf/pdfimages.o +0 -0
- data/pdf2json-0.52-source/xpdf/pdfinfo +0 -0
- data/pdf2json-0.52-source/xpdf/pdfinfo.cc +387 -0
- data/pdf2json-0.52-source/xpdf/pdfinfo.o +0 -0
- data/pdf2json-0.52-source/xpdf/pdftoppm.cc +203 -0
- data/pdf2json-0.52-source/xpdf/pdftops +0 -0
- data/pdf2json-0.52-source/xpdf/pdftops.cc +344 -0
- data/pdf2json-0.52-source/xpdf/pdftops.o +0 -0
- data/pdf2json-0.52-source/xpdf/pdftotext +0 -0
- data/pdf2json-0.52-source/xpdf/pdftotext.cc +333 -0
- data/pdf2json-0.52-source/xpdf/pdftotext.o +0 -0
- data/pdf2json-0.52-source/xpdf/print.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/printDis.xbm +6 -0
- data/pdf2json-0.52-source/xpdf/rightArrow.xbm +5 -0
- data/pdf2json-0.52-source/xpdf/rightArrowDis.xbm +5 -0
- data/pdf2json-0.52-source/xpdf/vms_make.com +129 -0
- data/pdf2json-0.52-source/xpdf/xpdf.cc +344 -0
- data/pdf2json-0.52-source/xpdf/xpdfIcon.xpm +62 -0
- data/pdf2json.gemspec +29 -0
- 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 */
|