Skip to content

Commit

Permalink
Add option to use reference bindings
Browse files Browse the repository at this point in the history
  • Loading branch information
mara004 committed Oct 23, 2023
1 parent b6141e7 commit 15c24df
Show file tree
Hide file tree
Showing 4 changed files with 38 additions and 14 deletions.
5 changes: 4 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,10 @@ Note, the APIs below may change any time and are mostly of internal interset.
- Version: If given, use the specified pdfium-binaries release. Otherwise, use the latest one.
* `$PYPDFIUM_MODULES=[raw,helpers]` defines which modules to include. Metadata adapts dynamically.
- May be used by packagers to decouple raw bindings and helpers, which can be important if packaging against system pdfium.
- It would also allow to install only the raw module without helpers, or only helpers with a custom raw module.
- Would also allow to install only the raw module without helpers, or only helpers with a custom raw module.
* `$PDFIUM_BINDINGS=reference` allows to override ctypesgen and use the reference bindings file `autorelease/bindings.py` instead.
- This is a convenience option to get pypdfium2 installed from source even if a working ctypesgen is not available in the install env.
- Warning: This might not be ABI-safe. Please make sure binary/bindings build headers match to avoid ABI issues.
[^platform_ids]: This is mainly of internal interest for packaging, so that wheels can be crafted for any platform without access to a native host.
Expand Down
1 change: 1 addition & 0 deletions docs/devel/changelog_staging.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,4 @@

# Changelog for next release
- Fixed faulty version repr (avoid trailing `+` if desc is empty).
- Added `PDFIUM_BINDINGS=reference` to use pre-built bindings when installing from source.
15 changes: 15 additions & 0 deletions setupsrc/pypdfium2_setup/packaging_base.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
# No external dependencies shall be imported in this file
# TODO improve consistency of variable names; think about variables to move in/out

import os
import re
import sys
import json
Expand All @@ -26,6 +27,10 @@
PlatTarget_Auto = "auto" # pdfium-binaries for host
VerTarget_Latest = "latest"

BindSpec_EnvVar = "PDFIUM_BINDINGS"
BindTarget_Ref = "reference"
BindTarget = os.environ.get(BindSpec_EnvVar, None)

ModulesSpec_EnvVar = "PYPDFIUM_MODULES"
ModuleRaw = "raw"
ModuleHelpers = "helpers"
Expand Down Expand Up @@ -158,7 +163,9 @@ def write_json(fp, data, indent=2):

def write_pdfium_info(dir, version, origin, flags=[]):
# TODO(future) embed library search path for use with a custom ctypesgen loader
# TODO consider embedding ctypesgen version info, probably using a separate file and class?
info = dict(**PdfiumVer.to_full(version, origin), origin=origin, flags=flags)
info["bindings"] = BindTarget_Ref if BindTarget == BindTarget_Ref else "generated"
write_json(dir/VersionFN, info)


Expand Down Expand Up @@ -359,6 +366,14 @@ def run_cmd(command, cwd, capture=False, check=True, str_cast=True, **kwargs):

def call_ctypesgen(target_dir, include_dir, pl_name, use_v8xfa=False, guard_symbols=False):

# quick and dirty patch to allow using the pre-built bindings instead of calling ctypesgen
if BindTarget == BindTarget_Ref:
print("Using ref bindings as requested by env var.",file=sys.stderr)
if use_v8xfa:
print("Warning: default ref bindings are not V8/XFA compatible, expecting prior overwrite.")
shutil.copyfile(RefBindingsFile, target_dir/BindingsFN)
return

# The commands below are tailored to our fork of ctypesgen, so make sure we have that
# Import ctypesgen only in this function so it does not have to be available for other setup tasks
import ctypesgen
Expand Down
31 changes: 18 additions & 13 deletions src/pypdfium2/version.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,15 +37,12 @@ def __getattr__(self, attr):
def __setattr__(self, name, value):
raise AttributeError(f"Version class is immutable - assignment '{name} = {value}' not allowed")

@cached_property
def version(self):
v = str(self.tag)
if self.desc:
v += "+" + str(self.desc)
return v

def __repr__(self):
return self.version

@cached_property
def version(self):
return self.tag + self.desc


# TODO handle data source & editable installs
Expand All @@ -68,13 +65,15 @@ def tag(self):
@cached_property
def desc(self):

desc = []
desc = ""
local_ver = []
if self.n_commits > 0:
desc += [str(self.n_commits), str(self.hash)]
local_ver += [str(self.n_commits), str(self.hash)]
if self.dirty:
desc += ["dirty"]
desc = ".".join(desc)
local_ver += ["dirty"]

if local_ver:
desc = "+" + ".".join(local_ver)
if self.data_source != "git":
desc += f":{self.data_source}"
if self.is_editable:
Expand Down Expand Up @@ -107,9 +106,13 @@ def tag(self):

@cached_property
def desc(self):
desc = f"{self.origin}"
desc = ""
if self.origin != "pdfium-binaries":
desc += f"+{self.origin}"
if self.flags:
desc += ":{%s}" % ','.join(self.flags)
desc += ":{%s}" % ",".join(self.flags)
if self.bindings != "generated":
desc += f"@bindings:{self.bindings}"
return desc


Expand Down Expand Up @@ -218,6 +221,8 @@ def desc(self):
- ``system``: Dynamically loaded from a standard system location using :func:`ctypes.util.find_library`.
flags (tuple[str]):
Tuple of pdfium feature flags. Empty for default build. (V8, XFA) for pdfium-binaries V8 build.
bindings (str):
Info on the used bindings (generated, reference). Note that the reference bindings can be ABI-unsafe. (This field is experimental. In the future, we may want to integrate bindings info separately with ctypesgen version.)
"""

# -----

0 comments on commit 15c24df

Please sign in to comment.