slpkg/slpkg/tracking.py
Dimitris Zlatanidis e79e1e6fda Clean from logging
2024-03-14 21:45:09 +02:00

110 lines
4.4 KiB
Python

#!/usr/bin/python3
# -*- coding: utf-8 -*-
from slpkg.configs import Configs
from slpkg.utilities import Utilities
from slpkg.views.asciibox import AsciiBox
from slpkg.sbos.dependencies import Requires
from slpkg.binaries.required import Required
from slpkg.repositories import Repositories
class Tracking(Configs):
""" Tracking of the package dependencies. """
def __init__(self, data: dict, packages: list, flags: list, repository: str):
super(Configs, self).__init__()
self.data: dict = data
self.packages: list = packages
self.flags: list = flags
self.repository: str = repository
self.ascii = AsciiBox()
self.utils = Utilities()
self.repos = Repositories()
self.llc: str = self.ascii.lower_left_corner
self.hl: str = self.ascii.horizontal_line
self.vl: str = self.ascii.vertical_line
self.package_version: str = ''
self.package_dependency_version: str = ''
self.package_requires: tuple = tuple()
self.package_line: str = ''
self.require_line: str = ''
self.count_requires: int = 0
self.require_length: int = 0
self.option_for_pkg_version: bool = self.utils.is_option(
('-p', '--pkg-version'), flags)
def package(self) -> None:
self.view_the_title()
for package in self.packages:
self.count_requires: int = 0
self.set_the_package_line(package)
self.set_package_requires(package)
self.view_the_main_package()
self.view_no_dependencies()
for require in self.package_requires:
self.count_requires += 1
self.set_the_package_require_line(require)
self.view_requires()
self.view_summary_of_tracking(package)
def view_the_title(self) -> None:
print(f"The list below shows the packages '{', '.join([pkg for pkg in self.packages])}' with dependencies:\n")
self.packages: tuple = tuple(self.utils.apply_package_pattern(self.data, self.packages))
def view_the_main_package(self) -> None:
print(self.package_line)
print(f"{'':>1}{self.llc}{self.hl}", end='')
def view_requires(self) -> None:
if self.count_requires == 1:
print(f"{'':>1}{self.require_line}")
else:
print(f"{'':>4}{self.require_line}")
def view_no_dependencies(self) -> None:
if not self.package_requires:
print(f"{'':>1}{self.cyan}No dependencies{self.endc}")
def set_the_package_line(self, package: str) -> None:
self.package_line: str = f'{self.yellow}{package}{self.endc}'
if self.option_for_pkg_version:
self.set_package_version(package)
self.package_line: str = f'{self.yellow}{package} {self.package_version}{self.endc}'
def set_the_package_require_line(self, require: str) -> None:
self.require_line: str = f'{self.cyan}{require}{self.endc}'
if self.option_for_pkg_version:
self.set_package_dependency_version(require)
self.require_line: str = (f'{self.cyan}{require:<{self.require_length}}{self.endc}'
f'{self.package_dependency_version}')
def set_package_dependency_version(self, require: str) -> None:
try:
self.package_dependency_version: str = f"{'':>1}(not included)"
if self.data.get(require):
self.package_dependency_version: str = f"{'':>1}{self.yellow}{self.data[require]['version']}{self.endc}"
except KeyError: # KeyError here because of the '%README%' as dependency
self.package_dependency_version: str = ''
def set_package_version(self, package: str) -> None:
self.package_version: str = self.data[package]['version']
def set_package_requires(self, package: str) -> None:
if self.repository not in [self.repos.sbo_repo_name, self.repos.ponce_repo_name]:
self.package_requires: tuple = Required(self.data, package).resolve()
else:
self.package_requires: tuple = Requires(self.data, package).resolve()
if self.package_requires:
self.require_length: int = max(len(name) for name in self.package_requires)
def view_summary_of_tracking(self, package: str) -> None:
print(f'\n{self.grey}{self.count_requires} dependencies for {package}{self.endc}\n')