Source code for pypdfium2.internal.utils

# SPDX-FileCopyrightText: 2024 geisserml <geisserml@gmail.com>
# SPDX-License-Identifier: Apache-2.0 OR BSD-3-Clause

import ctypes
import pypdfium2.raw as pdfium_c


[docs] def color_tohex(color, rev_byteorder): if len(color) != 4: raise ValueError("Color must consist of exactly 4 values.") if not all(0 <= c <= 255 for c in color): raise ValueError("Color value exceeds boundaries.") # different color interpretation with FPDF_REVERSE_BYTE_ORDER might be a bug? at least it's not documented. r, g, b, a = color channels = (a, b, g, r) if rev_byteorder else (a, r, g, b) c_color = 0 shift = 24 for c in channels: c_color |= c << shift shift -= 8 return c_color
[docs] def set_callback(struct, fname, callback): setattr(struct, fname, type( getattr(struct, fname) )(callback))
[docs] def is_buffer(buf, spec="r"): methods = [] assert set(spec).issubset( set("rw") ) if "r" in spec: methods += ["seek", "tell", "read", "readinto"] if "w" in spec: methods += ["write"] return all(callable(getattr(buf, a, None)) for a in methods)
class _buffer_reader: def __init__(self, buffer): self.buffer = buffer def __call__(self, _, position, p_buf, size): c_buf = ctypes.cast(p_buf, ctypes.POINTER(ctypes.c_char * size)) self.buffer.seek(position) self.buffer.readinto(c_buf.contents) return 1 class _buffer_writer: def __init__(self, buffer): self.buffer = buffer def __call__(self, _, data, size): block = ctypes.cast(data, ctypes.POINTER(ctypes.c_ubyte * size)) self.buffer.write(block.contents) return 1
[docs] def get_bufreader(buffer): file_len = buffer.seek(0, 2) buffer.seek(0) reader = pdfium_c.FPDF_FILEACCESS() reader.m_FileLen = file_len set_callback(reader, "m_GetBlock", _buffer_reader(buffer)) reader.m_Param = None to_hold = (reader.m_GetBlock, ) return reader, to_hold
[docs] def get_bufwriter(buffer): writer = pdfium_c.FPDF_FILEWRITE(version=1) set_callback(writer, "WriteBlock", _buffer_writer(buffer)) return writer
[docs] def pages_c_array(pages): if not pages: return None, 0 count = len(pages) c_array = (pdfium_c.FPDF_PAGE * count)(*[p.raw for p in pages]) return c_array, count