X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/a904f85549fdc34dc52730bd5058113b26099b77..bb3fed0b9f3318a5f36c14533896f1db4e3b8017:/scripts/buildorder.py diff --git a/scripts/buildorder.py b/scripts/buildorder.py index b6581534..10cdb316 100755 --- a/scripts/buildorder.py +++ b/scripts/buildorder.py @@ -31,6 +31,10 @@ def unique_everseen(iterable, key=None): def die(msg): sys.exit('ERROR: ' + msg) +def rchop(thestring, ending): + if thestring.endswith(ending): + return thestring[:-len(ending)] + return thestring class TermuxBuildFile(object): def __init__(self, path): @@ -38,28 +42,34 @@ class TermuxBuildFile(object): def _get_dependencies(self): pkg_dep_prefix = 'TERMUX_PKG_DEPENDS=' + pkg_build_dep_prefix = 'TERMUX_PKG_BUILD_DEPENDS=' subpkg_dep_prefix = 'TERMUX_SUBPKG_DEPENDS=' + comma_deps = '' - with open(self.path) as f: + with open(self.path, encoding="utf-8") as f: prefix = None for line in f: if line.startswith(pkg_dep_prefix): prefix = pkg_dep_prefix + elif line.startswith(pkg_build_dep_prefix): + prefix = pkg_build_dep_prefix elif line.startswith(subpkg_dep_prefix): prefix = subpkg_dep_prefix else: continue - comma_deps = line[len(prefix):].replace('"', '') + comma_deps += line[len(prefix):].replace('"', '').replace("'", '').replace("\n", ",") - return set([ - # Replace parenthesis to handle version qualifiers, as in "gcc (>= 5.0)": - re.sub(r'\(.*?\)', '', dep).strip() for dep in comma_deps.split(',') - if 'libandroid-support' not in dep - ]) + # Remove trailing ',' that is otherwise replacing the final newline + comma_deps = comma_deps[:-1] + if not comma_deps: + # no deps found + return set() - # no deps found - return set() + return set([ + # Replace parenthesis to handle version qualifiers, as in "gcc (>= 5.0)": + rchop(re.sub(r'\(.*?\)', '', dep).strip(), '-dev') for dep in comma_deps.split(',') + ]) class TermuxPackage(object): @@ -72,10 +82,13 @@ class TermuxPackage(object): # search package build.sh build_sh_path = os.path.join(self.dir, 'build.sh') if not os.path.isfile(build_sh_path): - raise Exception("build.sh not found") + raise Exception("build.sh not found for package '" + name + "'") self.buildfile = TermuxBuildFile(build_sh_path) self.deps = self.buildfile._get_dependencies() + if 'libandroid-support' not in self.deps and self.name != 'libandroid-support': + # Every package may depend on libandroid-support without declaring it: + self.deps.add('libandroid-support') # search subpackages self.subpkgs = [] @@ -165,9 +178,8 @@ def generate_full_buildorder(): if not leaf_pkgs: die('No package without dependencies - where to start?') - # Sort alphabetically, but with libandroid-support first (since dependency on libandroid-support - # does not need to be declared explicitly, so anything might in theory depend on it to build): - pkg_queue = sorted(leaf_pkgs, key=lambda p: '' if p.name == 'libandroid-support' else p.name) + # Sort alphabetically: + pkg_queue = sorted(leaf_pkgs, key=lambda p: p.name) # Topological sorting visited = set() @@ -217,6 +229,8 @@ def generate_targets_buildorder(targetnames): buildorder = [] for pkgname in targetnames: + if not pkgname in pkgs_map: + die('Dependencies for ' + pkgname + ' could not be calculated (skip dependency check with -s)') buildorder += deps_then_me(pkgs_map[pkgname]) return unique_everseen(buildorder)