mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2025-01-21 19:27:47 +01:00
Updated for binaries queries
This commit is contained in:
parent
26b299a2f1
commit
d25d6a6256
1 changed files with 23 additions and 10 deletions
|
@ -36,6 +36,7 @@ class Dependees(Configs):
|
||||||
self.flag_full_reverse: list = ['-E', '--full-reverse']
|
self.flag_full_reverse: list = ['-E', '--full-reverse']
|
||||||
self.flag_pkg_version: list = ['-p', '--pkg-version']
|
self.flag_pkg_version: list = ['-p', '--pkg-version']
|
||||||
self.flag_bin_repository: list = ['-B', '--bin-repo=']
|
self.flag_bin_repository: list = ['-B', '--bin-repo=']
|
||||||
|
self.bin_repo_dict: dict = {}
|
||||||
|
|
||||||
def find(self, repo: str) -> None:
|
def find(self, repo: str) -> None:
|
||||||
""" Collecting the dependees. """
|
""" Collecting the dependees. """
|
||||||
|
@ -43,15 +44,16 @@ class Dependees(Configs):
|
||||||
f"packages that dependees on '{', '.join([p for p in self.packages])}':\n")
|
f"packages that dependees on '{', '.join([p for p in self.packages])}':\n")
|
||||||
|
|
||||||
self.packages: list = self.utils.apply_package_pattern(self.flags, self.packages, repo)
|
self.packages: list = self.utils.apply_package_pattern(self.flags, self.packages, repo)
|
||||||
|
self.bin_repo_dict: dict = BinQueries(repo).repository_data()
|
||||||
|
|
||||||
for pkg in self.packages:
|
for pkg in self.packages:
|
||||||
dependees: list = list(self.find_requires(pkg, repo))
|
dependees: list = list(self.find_requires(pkg))
|
||||||
|
|
||||||
package: str = f'{self.byellow}{pkg}{self.endc}'
|
package: str = f'{self.byellow}{pkg}{self.endc}'
|
||||||
|
|
||||||
if self.utils.is_option(self.flag_pkg_version, self.flags):
|
if self.utils.is_option(self.flag_pkg_version, self.flags):
|
||||||
if self.utils.is_option(self.flag_bin_repository, self.flags):
|
if self.utils.is_option(self.flag_bin_repository, self.flags):
|
||||||
version: str = BinQueries(pkg, repo).version()
|
version: str = self.bin_repo_dict[package][0]
|
||||||
else:
|
else:
|
||||||
version: str = SBoQueries(pkg).version()
|
version: str = SBoQueries(pkg).version()
|
||||||
|
|
||||||
|
@ -71,7 +73,7 @@ class Dependees(Configs):
|
||||||
if self.utils.is_option(self.flag_pkg_version, self.flags):
|
if self.utils.is_option(self.flag_pkg_version, self.flags):
|
||||||
|
|
||||||
if self.utils.is_option(self.flag_bin_repository, self.flags):
|
if self.utils.is_option(self.flag_bin_repository, self.flags):
|
||||||
version: str = BinQueries(dep[0], repo).version()
|
version: str = self.bin_repo_dict[package][0]
|
||||||
else:
|
else:
|
||||||
version: str = SBoQueries(dep[0]).version()
|
version: str = SBoQueries(dep[0]).version()
|
||||||
|
|
||||||
|
@ -91,13 +93,24 @@ class Dependees(Configs):
|
||||||
|
|
||||||
print(f'\n{self.grey}{len(dependees)} dependees for {pkg}{self.endc}\n')
|
print(f'\n{self.grey}{len(dependees)} dependees for {pkg}{self.endc}\n')
|
||||||
|
|
||||||
def find_requires(self, pkg: str, repo) -> Generator[str, None, None]:
|
def find_requires(self, pkg: str) -> Generator[str, None, None]:
|
||||||
""" Find requires that slackbuild dependees. """
|
""" Find requires that slackbuild dependees. """
|
||||||
|
repo_dict: dict = {}
|
||||||
if self.utils.is_option(self.flag_bin_repository, self.flags):
|
if self.utils.is_option(self.flag_bin_repository, self.flags):
|
||||||
requires: list = BinQueries(pkg, repo).all_package_names_with_required()
|
repo_dict: dict = self.bin_repo_dict
|
||||||
else:
|
# # requires: list = BinQueries(pkg, repo).all_package_names_with_required()
|
||||||
requires: list = SBoQueries('').all_sbo_and_requires()
|
# else:
|
||||||
|
# requires: list = SBoQueries('').all_sbo_and_requires()
|
||||||
|
|
||||||
for req in requires:
|
for repo in repo_dict.values():
|
||||||
if [r for r in req[1].split() if r == pkg]:
|
if repo_dict.get(pkg):
|
||||||
yield req
|
for req in repo[6].split():
|
||||||
|
if req == pkg:
|
||||||
|
yield repo[6].split()
|
||||||
|
|
||||||
|
# for req in requires:
|
||||||
|
# # if req == pkg:
|
||||||
|
# # for r in req[1].split():
|
||||||
|
# # if r == pkg:
|
||||||
|
# if [r for r in req[1].split() if r == pkg]:
|
||||||
|
# yield req
|
||||||
|
|
Loading…
Reference in a new issue