Module ffi.mupdf

MuPDF API

This is a FFI wrapper for what was a Lua-based API in the past Some kind of C wrapper is needed for muPDF since muPDF uses a setjmp/longjmp based approach to error/exception handling.

That's one of the very few things we can't deal with using LuaJIT's FFI.

Functions

openDocument (filename) Opens a document.
renderImage (data, size, width, height) Renders image data.
renderImageFile (filename, width, height) Renders image file.
scaleBlitBuffer (bb, width, height) Scales a blitbuffer.

Issues

ffi.mupdf-fixme16

: Don't make cache_size too low, at least not until we bump MµPDF,

     as there's a pernicious issue that corrupts its store cache on overcommit on old versions.
     c.f., https://github.com/koreader/koreader/issues/7627
     (FZ_STORE_DEFAULT is 256MB, we used to set it to 8MB).
     And when we bump MµPDF, it'll likely have *more* stuff to store in there,
      so, don't make that too low, period ;).
      NOTE: Revisit when we bump MµPDF by doing a few tests with the tracing memory allocators,
            as even 32MB is likely to be too conservative.


Functions

openDocument (filename)
Opens a document.

Parameters:

  • filename
renderImage (data, size, width, height)
Renders image data.

Parameters:

  • data
  • size
  • width
  • height
renderImageFile (filename, width, height)
Renders image file.

Parameters:

  • filename
  • width
  • height
scaleBlitBuffer (bb, width, height)
Scales a blitbuffer.

MµPDF's scaling is of much better quality than the very naive implementation in blitbuffer.lua. (see fzscalepixmap_cached() in mupdf/source/fitz/draw-scale-simple.c). Same arguments as BlitBuffer:scale() for easy replacement.

Unlike BlitBuffer:scale(), this ignores the blitbuffer's rotation (i.e., where possible, we simply wrap the BlitBuffer's data in a fitz pixmap, with no data copy, so the buffer's native memory layout is followed). If you actually want to preserve the rotation, you'll have to fudge with the width & height arguments and tweak the returned buffer's rotation flag, or go through a temporary copy to ensure that the buffer's memory is laid out accordingly.

Parameters:

  • bb
  • width
  • height We need first to convert our BlitBuffer to a pixmap

Issues

ffi.mupdf-fixme16

: Don't make cache_size too low, at least not until we bump MµPDF,

     as there's a pernicious issue that corrupts its store cache on overcommit on old versions.
     c.f., https://github.com/koreader/koreader/issues/7627
     (FZ_STORE_DEFAULT is 256MB, we used to set it to 8MB).
     And when we bump MµPDF, it'll likely have *more* stuff to store in there,
      so, don't make that too low, period ;).
      NOTE: Revisit when we bump MµPDF by doing a few tests with the tracing memory allocators,
            as even 32MB is likely to be too conservative.
generated by LDoc 1.5.0 Last updated 2025-01-24 21:45:56