diff --git a/pyproject.toml b/pyproject.toml index 339b6ca..4ed239d 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -26,6 +26,8 @@ dependencies = [ "pyelftools", # TODO(#264): Remove when Python 3.7 support is removed. "importlib_metadata; python_version<'3.8'", + # TODO(#265): Remove when Python 3.8 support is removed. + "importlib_resources; python_version<'3.9'", ] description = "Build static self-extracting app from dynamic executable" license = {file = "LICENSE.txt"} diff --git a/staticx/assets.py b/staticx/assets.py index e275c1f..76f0576 100644 --- a/staticx/assets.py +++ b/staticx/assets.py @@ -1,11 +1,19 @@ -import pkg_resources +import sys from .utils import copy_fileobj_to_tempfile +# TODO(#265): Remove backport when Python 3.8 support is removed. +# importlib.resources.files() was added in Python 3.9. +if sys.version_info >= (3, 9): + import importlib.resources as importlib_resources +else: + import importlib_resources # backport + + def locate_asset(name, debug): mode = 'debug' if debug else 'release' path = '/'.join(('assets', mode, name)) try: - return pkg_resources.resource_stream(__name__, path) + return importlib_resources.files("staticx").joinpath(path).open("rb") except FileNotFoundError: raise KeyError(f"Asset not found: {name!r} (mode={mode!r})") diff --git a/staticx/version.py b/staticx/version.py index a2807fd..8abf568 100644 --- a/staticx/version.py +++ b/staticx/version.py @@ -62,7 +62,7 @@ def get_version(): # Otherwise, we're either installed (e.g. via pip), or running from # an 'sdist' source distribution, and have a local PKG_INFO file. - # TODO(#242): Remove backport when Python 3.7 support is removed. + # TODO(#264): Remove backport when Python 3.7 support is removed. if sys.version_info >= (3, 8): import importlib.metadata as importlib_metadata else: