Added local copy option to dependency check

This commit is contained in:
Vladimir Ivan
2022-07-19 10:27:41 +01:00
committed by Valentin
parent 984a1ccec0
commit a99d31e661

View File

@@ -6,11 +6,12 @@ import re
import shutil
import stat
import struct
import importlib
from ...appimage import build_appimage
from ...utils.compat import decode
from ...utils.deps import PREFIX
from ...utils.fs import copy_file, make_tree, remove_file, remove_tree
from ...utils.fs import copy_file, copy_tree, make_tree, remove_file, remove_tree
from ...utils.log import log
from ...utils.system import system
from ...utils.template import copy_template, load_template
@@ -259,6 +260,18 @@ def execute(appdir, name=None, python_version=None, linux_tag=None,
if requirement.startswith('git+'):
url, name = os.path.split(requirement)
log('BUNDLE', name + ' from ' + url[4:])
elif requirement.startswith('local+'):
_, name = requirement.split('+')
module = importlib.util.find_spec(name).origin
if module.endswith('.so'):
destination = f'AppDir/opt/python{python_version}/lib/python{python_version}/site-packages/'
copy_file(module, destination)
else:
destination = f'AppDir/opt/python{python_version}/lib/python{python_version}/site-packages/{name}/'
source = os.path.dirname(module)
copy_tree(source, destination)
log('BUNDLE', f'{name} (local)')
continue
else:
log('BUNDLE', requirement)
system(('./AppDir/AppRun', '-m', 'pip', 'install', '-U', in_tree_build,