From b4d6245c84fdbabed108434b800a53cd91fc5b46 Mon Sep 17 00:00:00 2001 From: V3n3RiX Date: Fri, 7 Apr 2023 18:26:10 +0100 Subject: backend : rewrite the dependency solver in a more efficient way --- src/backend/solvedeps.py | 74 +++++++++++++----------------------------------- 1 file changed, 20 insertions(+), 54 deletions(-) (limited to 'src/backend/solvedeps.py') diff --git a/src/backend/solvedeps.py b/src/backend/solvedeps.py index 407f4f4..d388196 100644 --- a/src/backend/solvedeps.py +++ b/src/backend/solvedeps.py @@ -8,66 +8,28 @@ import sisyphus.getfs @animation.wait('resolving dependencies') -def pkg(pkgname): +def start(pkgname=None): bin_list = [] src_list = [] need_cfg = int() - p_exe = subprocess.Popen(['emerge', '--quiet', '--pretend', '--getbinpkg', '--rebuilt-binaries', '--with-bdeps=y', - '--misspell-suggestion=n', '--fuzzy-search=n'] + list(pkgname), stdout=subprocess.PIPE, stderr=subprocess.PIPE) - stdout, stderr = p_exe.communicate() - - for p_out in stderr.decode('utf-8').splitlines(): - if "The following keyword changes are necessary to proceed:" in p_out: - need_cfg = int(1) - - if "The following mask changes are necessary to proceed:" in p_out: - need_cfg = int(1) - - if "The following USE changes are necessary to proceed:" in p_out: - need_cfg = int(1) - - if "The following REQUIRED_USE flag constraints are unsatisfied:" in p_out: - need_cfg = int(1) - - if "One of the following masked packages is required to complete your request:" in p_out: - need_cfg = int(1) - - for p_out in stdout.decode('utf-8').splitlines(): - if "[binary" in p_out: - is_bin = p_out.split("]")[1].split("[")[0].strip(" ") - bin_list.append(is_bin) - - if "[ebuild" in p_out: - is_src = p_out.split("]")[1].split("[")[0].strip(" ") - src_list.append(is_src) - - pickle.dump([bin_list, src_list, need_cfg], open(os.path.join( - sisyphus.getfs.p_mtd_dir, "sisyphus_pkgdeps.pickle"), "wb")) + if pkgname: + args = ['--quiet', '--pretend', '--getbinpkg', '--rebuilt-binaries', + '--with-bdeps=y', '--misspell-suggestion=n', '--fuzzy-search=n'] + list(pkgname) + else: + args = ['--quiet', '--update', '--deep', '--newuse', '--pretend', '--getbinpkg', '--rebuilt-binaries', + '--backtrack=100', '--with-bdeps=y', '--misspell-suggestion=n', '--fuzzy-search=n', '@world'] -@animation.wait('resolving dependencies') -def world(): - bin_list = [] - src_list = [] - need_cfg = int() - p_exe = subprocess.Popen(['emerge', '--quiet', '--update', '--deep', '--newuse', '--pretend', '--getbinpkg', '--rebuilt-binaries', '--backtrack=100', - '--with-bdeps=y', '--misspell-suggestion=n', '--fuzzy-search=n', '@world'], stdout=subprocess.PIPE, stderr=subprocess.PIPE) + p_exe = subprocess.Popen( + ['emerge'] + args, stdout=subprocess.PIPE, stderr=subprocess.PIPE) stdout, stderr = p_exe.communicate() for p_out in stderr.decode('utf-8').splitlines(): - if "The following keyword changes are necessary to proceed:" in p_out: - need_cfg = int(1) - - if "The following mask changes are necessary to proceed:" in p_out: - need_cfg = int(1) - - if "The following USE changes are necessary to proceed:" in p_out: - need_cfg = int(1) - - if "The following REQUIRED_USE flag constraints are unsatisfied:" in p_out: - need_cfg = int(1) - - if "One of the following masked packages is required to complete your request:" in p_out: + if any(key in p_out for key in ["The following keyword changes are necessary to proceed:", + "The following mask changes are necessary to proceed:", + "The following USE changes are necessary to proceed:", + "The following REQUIRED_USE flag constraints are unsatisfied:", + "One of the following masked packages is required to complete your request:"]): need_cfg = int(1) for p_out in stdout.decode('utf-8').splitlines(): @@ -79,5 +41,9 @@ def world(): is_src = p_out.split("]")[1].split("[")[0].strip(" ") src_list.append(is_src) - pickle.dump([bin_list, src_list, need_cfg], open(os.path.join( - sisyphus.getfs.p_mtd_dir, "sisyphus_worlddeps.pickle"), "wb")) + if pkgname: + pickle.dump([bin_list, src_list, need_cfg], open(os.path.join( + sisyphus.getfs.p_mtd_dir, "sisyphus_pkgdeps.pickle"), "wb")) + else: + pickle.dump([bin_list, src_list, need_cfg], open(os.path.join( + sisyphus.getfs.p_mtd_dir, "sisyphus_worlddeps.pickle"), "wb")) -- cgit v1.2.3