mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2025-01-18 10:26:29 +01:00
Merge branch 'develop'
This commit is contained in:
commit
83f44ffdb9
11 changed files with 51 additions and 53 deletions
|
@ -1,3 +1,11 @@
|
||||||
|
4.4.6 - 06/01/2023
|
||||||
|
Updated:
|
||||||
|
- Improve speed for dependees
|
||||||
|
Fixed:
|
||||||
|
- summary for build
|
||||||
|
Remove:
|
||||||
|
- python-toml dependency
|
||||||
|
|
||||||
4.4.5 - 03/01/2023
|
4.4.5 - 03/01/2023
|
||||||
Added:
|
Added:
|
||||||
- New modern view mode style
|
- New modern view mode style
|
||||||
|
|
|
@ -23,7 +23,6 @@ Requirements
|
||||||
SQLAlchemy >= 1.4.36
|
SQLAlchemy >= 1.4.36
|
||||||
pythondialog >= 3.5.3
|
pythondialog >= 3.5.3
|
||||||
progress >= 1.6
|
progress >= 1.6
|
||||||
toml >= 0.10.2
|
|
||||||
|
|
||||||
Install
|
Install
|
||||||
-------
|
-------
|
||||||
|
@ -32,8 +31,8 @@ Install from the official third-party `SBo repository <https://slackbuilds.org/r
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
$ tar xvf slpkg-4.4.5.tar.gz
|
$ tar xvf slpkg-4.4.6.tar.gz
|
||||||
$ cd slpkg-4.4.5
|
$ cd slpkg-4.4.6
|
||||||
$ ./install.sh
|
$ ./install.sh
|
||||||
|
|
||||||
Screenshots
|
Screenshots
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
SQLAlchemy >= 1.4.46
|
SQLAlchemy >= 1.4.46
|
||||||
pythondialog >= 3.5.3
|
pythondialog >= 3.5.3
|
||||||
progress >= 1.6
|
progress >= 1.6
|
||||||
toml >= 0.10.2
|
|
|
@ -1,6 +1,6 @@
|
||||||
[metadata]
|
[metadata]
|
||||||
name = slpkg
|
name = slpkg
|
||||||
version = 4.4.5
|
version = 4.4.6
|
||||||
license_file = LICENSE
|
license_file = LICENSE
|
||||||
author = Dimitris Zlatanidis
|
author = Dimitris Zlatanidis
|
||||||
author_email = d.zlatanidis@gmail.com
|
author_email = d.zlatanidis@gmail.com
|
||||||
|
@ -41,7 +41,6 @@ install_requires =
|
||||||
SQLAlchemy >= 1.4.36
|
SQLAlchemy >= 1.4.36
|
||||||
pythondialog >= 3.5.3
|
pythondialog >= 3.5.3
|
||||||
progress >= 1.6
|
progress >= 1.6
|
||||||
toml >= 0.10.2
|
|
||||||
include_package_data = True
|
include_package_data = True
|
||||||
|
|
||||||
[options.packages.find]
|
[options.packages.find]
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
from progress.spinner import PixelSpinner
|
|
||||||
|
|
||||||
from slpkg.configs import Configs
|
from slpkg.configs import Configs
|
||||||
from slpkg.views.ascii import Ascii
|
from slpkg.views.ascii import Ascii
|
||||||
from slpkg.queries import SBoQueries
|
from slpkg.models.models import SBoTable
|
||||||
|
from slpkg.models.models import session as Session
|
||||||
|
|
||||||
|
|
||||||
class Dependees:
|
class Dependees:
|
||||||
|
@ -15,19 +14,19 @@ class Dependees:
|
||||||
self.packages = packages
|
self.packages = packages
|
||||||
self.flags = flags
|
self.flags = flags
|
||||||
self.configs = Configs
|
self.configs = Configs
|
||||||
|
self.session = Session
|
||||||
self.ascii = Ascii()
|
self.ascii = Ascii()
|
||||||
self.llc = self.ascii.lower_left_corner
|
self.llc = self.ascii.lower_left_corner
|
||||||
self.hl = self.ascii.horizontal_line
|
self.hl = self.ascii.horizontal_line
|
||||||
self.var = self.ascii.vertical_and_right
|
self.var = self.ascii.vertical_and_right
|
||||||
self.colors = self.configs.colour
|
self.colors = self.configs.colour
|
||||||
self.colors = self.configs.colour
|
|
||||||
self.color = self.colors()
|
self.color = self.colors()
|
||||||
self.bold = self.color['bold']
|
self.bold = self.color['bold']
|
||||||
self.violet = self.color['violet']
|
self.violet = self.color['violet']
|
||||||
self.cyan = self.color['cyan']
|
self.cyan = self.color['cyan']
|
||||||
self.grey = self.color['grey']
|
self.grey = self.color['grey']
|
||||||
self.yellow = self.color['yellow']
|
self.yellow = self.color['yellow']
|
||||||
self.bviolet = f'{self.bold}{self.violet}'
|
self.byellow = f'{self.bold}{self.yellow}'
|
||||||
self.endc = self.color['endc']
|
self.endc = self.color['endc']
|
||||||
|
|
||||||
def slackbuilds(self):
|
def slackbuilds(self):
|
||||||
|
@ -35,40 +34,30 @@ class Dependees:
|
||||||
print(f"The list below shows the "
|
print(f"The list below shows the "
|
||||||
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")
|
||||||
|
|
||||||
dependees = {}
|
for pkg in self.packages:
|
||||||
spinner = PixelSpinner(f'{self.endc}Collecting the data... {self.bviolet}')
|
dependees = list(self.find_requires(pkg))
|
||||||
for package in self.packages:
|
print(f'{self.byellow}{pkg}{self.endc}')
|
||||||
found = [] # Reset list every package
|
print(f' {self.llc}{self.hl}', end='')
|
||||||
sbos = SBoQueries('').sbos()
|
if not dependees:
|
||||||
|
print(f'{self.cyan}No dependees{self.endc}')
|
||||||
for sbo in sbos:
|
|
||||||
requires = SBoQueries(sbo).requires()
|
|
||||||
spinner.next()
|
|
||||||
|
|
||||||
if package in requires:
|
|
||||||
found.append(sbo)
|
|
||||||
dependees[package] = found
|
|
||||||
|
|
||||||
last = f' {self.llc}{self.hl}'
|
|
||||||
print('\n')
|
|
||||||
if dependees:
|
|
||||||
for key, value in dependees.items():
|
|
||||||
print(f'{self.yellow}{key}{self.endc}')
|
|
||||||
print(end=f'\r{last}')
|
|
||||||
char = f' {self.var}{self.hl}'
|
|
||||||
|
|
||||||
for i, v in enumerate(value, start=1):
|
|
||||||
if i == len(value):
|
|
||||||
char = last
|
|
||||||
|
|
||||||
|
sp = ' ' * 4
|
||||||
|
for i, dep in enumerate(dependees, start=1):
|
||||||
if i == 1:
|
if i == 1:
|
||||||
print(f'{self.cyan}{v}{self.endc}')
|
print(f' {self.cyan}{dep[0]}{self.endc}')
|
||||||
else:
|
else:
|
||||||
print(f'{" " * 3}{self.cyan}{v}{self.endc}')
|
print(f'{sp}{self.cyan}{dep[0]}{self.endc}')
|
||||||
|
|
||||||
if '--full-reverse' in self.flags:
|
if '--full-reverse' in self.flags:
|
||||||
print(f'{" " * 4}{char} {" ".join([req for req in SBoQueries(v).requires()])}')
|
if i == len(dependees):
|
||||||
|
print(" " * 4 + f' {self.llc}{self.hl} {self.violet}{dep[1]}{self.endc}')
|
||||||
print(f'\n{self.grey}{len(value)} dependees for {key}{self.endc}\n')
|
|
||||||
else:
|
else:
|
||||||
print(f'{self.endc}No dependees found.\n')
|
print(" " * 4 + f' {self.var}{self.hl} {self.violet}{dep[1]}{self.endc}')
|
||||||
|
print(f'\n{self.grey}{len(dependees)} dependees for {pkg}{self.endc}\n')
|
||||||
|
|
||||||
|
def find_requires(self, sbo):
|
||||||
|
""" Find requires that slackbuild dependees. """
|
||||||
|
requires = self.session.query(SBoTable.name, SBoTable.requires).all()
|
||||||
|
for req in requires:
|
||||||
|
if [r for r in req[1].split() if r == sbo]:
|
||||||
|
yield req
|
||||||
|
|
|
@ -20,8 +20,10 @@ class Downloader:
|
||||||
self.configs = Configs
|
self.configs = Configs
|
||||||
self.colors = self.configs.colour
|
self.colors = self.configs.colour
|
||||||
self.color = self.colors()
|
self.color = self.colors()
|
||||||
|
self.bold = self.color['bold']
|
||||||
self.green = self.color['green']
|
self.green = self.color['green']
|
||||||
self.yellow = self.color['yellow']
|
self.yellow = self.color['yellow']
|
||||||
|
self.byellow = f'{self.bold}{self.yellow}'
|
||||||
self.endc = self.color['endc']
|
self.endc = self.color['endc']
|
||||||
self.progress = ProgressBar()
|
self.progress = ProgressBar()
|
||||||
self.stderr = None
|
self.stderr = None
|
||||||
|
@ -52,7 +54,7 @@ class Downloader:
|
||||||
|
|
||||||
# Terminate process 2 if process 1 finished
|
# Terminate process 2 if process 1 finished
|
||||||
if not p1.is_alive():
|
if not p1.is_alive():
|
||||||
print(f'{self.endc}{self.yellow} Done{self.endc}', end='')
|
print(f'{self.endc}{self.byellow} Done{self.endc}', end='')
|
||||||
p2.terminate()
|
p2.terminate()
|
||||||
|
|
||||||
# Wait until process 2 finish
|
# Wait until process 2 finish
|
||||||
|
|
|
@ -23,7 +23,9 @@ class RemovePackages:
|
||||||
self.configs = Configs
|
self.configs = Configs
|
||||||
self.colors = self.configs.colour
|
self.colors = self.configs.colour
|
||||||
self.color = self.colors()
|
self.color = self.colors()
|
||||||
|
self.bold = self.color['bold']
|
||||||
self.yellow = self.color['yellow']
|
self.yellow = self.color['yellow']
|
||||||
|
self.byellow = f'{self.bold}{self.yellow}'
|
||||||
self.red = self.color['red']
|
self.red = self.color['red']
|
||||||
self.endc = self.color['endc']
|
self.endc = self.color['endc']
|
||||||
self.installed_packages = []
|
self.installed_packages = []
|
||||||
|
@ -93,7 +95,7 @@ class RemovePackages:
|
||||||
|
|
||||||
# Terminate process 2 if process 1 finished
|
# Terminate process 2 if process 1 finished
|
||||||
if not p1.is_alive():
|
if not p1.is_alive():
|
||||||
print(f'{self.endc}{self.yellow} Done{self.endc}', end='')
|
print(f'{self.endc}{self.byellow} Done{self.endc}', end='')
|
||||||
p2.terminate()
|
p2.terminate()
|
||||||
|
|
||||||
# Wait until process 2 finish
|
# Wait until process 2 finish
|
||||||
|
|
|
@ -37,9 +37,11 @@ class Slackbuilds:
|
||||||
self.configs = Configs
|
self.configs = Configs
|
||||||
self.colors = self.configs.colour
|
self.colors = self.configs.colour
|
||||||
self.color = self.colors()
|
self.color = self.colors()
|
||||||
|
self.bold = self.color['bold']
|
||||||
self.cyan = self.color['cyan']
|
self.cyan = self.color['cyan']
|
||||||
self.red = self.color['red']
|
self.red = self.color['red']
|
||||||
self.yellow = self.color['yellow']
|
self.yellow = self.color['yellow']
|
||||||
|
self.byellow = f'{self.bold}{self.yellow}'
|
||||||
self.endc = self.color['endc']
|
self.endc = self.color['endc']
|
||||||
self.install_order = []
|
self.install_order = []
|
||||||
self.dependencies = []
|
self.dependencies = []
|
||||||
|
@ -299,7 +301,7 @@ class Slackbuilds:
|
||||||
|
|
||||||
# Terminate process 2 if process 1 finished
|
# Terminate process 2 if process 1 finished
|
||||||
if not p1.is_alive():
|
if not p1.is_alive():
|
||||||
print(f'{self.endc}{self.yellow} Done{self.endc}', end='')
|
print(f'{self.endc}{self.byellow} Done{self.endc}', end='')
|
||||||
p2.terminate()
|
p2.terminate()
|
||||||
|
|
||||||
# Wait until process 2 finish
|
# Wait until process 2 finish
|
||||||
|
|
|
@ -5,7 +5,7 @@ class Version:
|
||||||
""" Print the version. """
|
""" Print the version. """
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.version_info = (4, 4, 5)
|
self.version_info = (4, 4, 6)
|
||||||
self.version = '{0}.{1}.{2}'.format(*self.version_info)
|
self.version = '{0}.{1}.{2}'.format(*self.version_info)
|
||||||
self.license = 'MIT License'
|
self.license = 'MIT License'
|
||||||
self.author = 'Dimitris Zlatanidis (dslackw)'
|
self.author = 'Dimitris Zlatanidis (dslackw)'
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
import urllib3
|
import urllib3
|
||||||
|
|
||||||
from slpkg.configs import Configs
|
from slpkg.configs import Configs
|
||||||
from slpkg.models.models import SBoTable
|
|
||||||
from slpkg.queries import SBoQueries
|
from slpkg.queries import SBoQueries
|
||||||
|
from slpkg.models.models import SBoTable
|
||||||
from slpkg.models.models import session as Session
|
from slpkg.models.models import session as Session
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -231,8 +231,6 @@ class ViewMessage:
|
||||||
upgrade += 1
|
upgrade += 1
|
||||||
elif installed and option == 'remove':
|
elif installed and option == 'remove':
|
||||||
remove += 1
|
remove += 1
|
||||||
else:
|
|
||||||
build += 1
|
|
||||||
|
|
||||||
self.draw_bottom_line()
|
self.draw_bottom_line()
|
||||||
|
|
||||||
|
@ -241,7 +239,7 @@ class ViewMessage:
|
||||||
f'installed and {upgrade} will be upgraded.{self.endc}')
|
f'installed and {upgrade} will be upgraded.{self.endc}')
|
||||||
|
|
||||||
elif option == 'build':
|
elif option == 'build':
|
||||||
print(f'{self.grey}Total {build} packages '
|
print(f'{self.grey}Total {len(slackbuilds)} packages '
|
||||||
f'will be build in {self.configs.tmp_path} folder.{self.endc}')
|
f'will be build in {self.configs.tmp_path} folder.{self.endc}')
|
||||||
|
|
||||||
elif option == 'remove':
|
elif option == 'remove':
|
||||||
|
|
Loading…
Reference in a new issue