Merge branch 'develop'

This commit is contained in:
Dimitris Zlatanidis 2022-05-12 20:19:42 +03:00
commit b69d90c986
13 changed files with 37 additions and 21 deletions

View file

@ -1,3 +1,9 @@
3.9.8 - 12/05/2022
Bugfix:
- Flag (--repos=) TypeError: exceptions must derive from BaseException
Updated:
- Slackbuild script switch to bash shell
3.9.7 - 09/05/2022 3.9.7 - 09/05/2022
Fixed: Fixed:
- Stderr error output - Stderr error output

View file

@ -1,4 +1,4 @@
# slpkg 3.9.7 # slpkg 3.9.8
Slpkg is a powerful software package manager that installs, updates, and removes packages on Slpkg is a powerful software package manager that installs, updates, and removes packages on
[Slackware](http://www.slackware.com/) based systems. It automatically computes dependencies and [Slackware](http://www.slackware.com/) based systems. It automatically computes dependencies and

View file

@ -1,4 +1,4 @@
#!/bin/sh #!/bin/bash
# install.sh file is part of slpkg. # install.sh file is part of slpkg.

View file

@ -1,4 +1,4 @@
#!/bin/sh #!/bin/bash
# Slackware build script for slpkg # Slackware build script for slpkg

View file

@ -81,7 +81,7 @@ class MetaData:
__all__ = "slpkg" __all__ = "slpkg"
__author__ = "dslackw" __author__ = "dslackw"
__version_info__ = (3, 9, 7) __version_info__ = (3, 9, 8)
__version__ = "{0}.{1}.{2}".format(*__version_info__) __version__ = "{0}.{1}.{2}".format(*__version_info__)
__license__ = "GNU General Public License v3 (GPLv3)" __license__ = "GNU General Public License v3 (GPLv3)"
__email__ = "d.zlatanidis@gmail.com" __email__ = "d.zlatanidis@gmail.com"

View file

@ -225,7 +225,7 @@ def usage(repo, stderr):
else: else:
error_repo = (f"slpkg: Error: Repository '{repo}' does not exist" error_repo = (f"slpkg: Error: Repository '{repo}' does not exist"
"\n") "\n")
raise(f"\n {error_repo}") raise SystemExit(f"\n{error_repo}")
print(usage.__doc__) print(usage.__doc__)
print("For more information try 'slpkg -h, --help' or view manpage\n") print("For more information try 'slpkg -h, --help' or view manpage\n")
if stderr == 1: if stderr == 1:

View file

@ -61,8 +61,7 @@ class Auto:
try: try:
self.choice = input(" > ") self.choice = input(" > ")
except EOFError: except EOFError:
print() raise SystemExit("\n")
raise SystemExit()
if self.choice in self.commands.keys(): if self.choice in self.commands.keys():
print(f" \x1b[1A{self.cyan}{self.commands[self.choice]}" print(f" \x1b[1A{self.cyan}{self.commands[self.choice]}"
f"{self.endc}", end="\n\n") f"{self.endc}", end="\n\n")

View file

@ -67,30 +67,33 @@ class BlackList(Utils):
def black_listed(self): def black_listed(self):
"""Print blacklist packages """Print blacklist packages
""" """
print("Packages in the blacklist:\n") print("Packages in the blacklist:")
for black in list(self.black_filter()): for black in list(self.black_filter()):
if black: if black:
print(f"{self.green}{black}{self.endc}") print(f"{self.green}{black}{self.endc}")
print()
def black_add(self, pkgs): def black_add(self, pkgs):
"""Add blacklist packages if not exist """Add blacklist packages if not exist
""" """
blacklist = list(self.black_filter()) blacklist = list(self.black_filter())
pkgs = set(pkgs) pkgs = set(pkgs)
print("Add packages in the blacklist:\n") print("Add packages in the blacklist:")
with open(self.blackfile, "a") as black_conf: with open(self.blackfile, "a") as black_conf:
for pkg in pkgs: for pkg in pkgs:
if pkg not in blacklist: if pkg not in blacklist:
print(f"{self.green}{pkg}{self.endc}") print(f"{self.green}{pkg}{self.endc}")
black_conf.write(pkg + "\n") black_conf.write(pkg + "\n")
print()
def black_remove(self, pkgs): def black_remove(self, pkgs):
"""Remove packages from blacklist """Remove packages from blacklist
""" """
print("Remove packages from the blacklist:\n") print("Remove packages from the blacklist:")
with open(self.blackfile, "w") as remove: with open(self.blackfile, "w") as remove:
for line in self.black_conf.splitlines(): for line in self.black_conf.splitlines():
if line not in pkgs: if line not in pkgs:
remove.write(line + "\n") remove.write(line + "\n")
else: else:
print(f"{self.red}{line}{self.endc}") print(f"{self.red}{line}{self.endc}")
print()

View file

@ -43,8 +43,8 @@ class DialogUtil:
def imp_dialog(self): def imp_dialog(self):
try: try:
from dialog import Dialog from dialog import Dialog
except ImportError: except ImportError as er:
raise SystemExit() raise SystemExit(er)
self.d = Dialog(dialog="dialog", autowidgetsize=True) self.d = Dialog(dialog="dialog", autowidgetsize=True)
def checklist(self): def checklist(self):

View file

@ -300,7 +300,8 @@ class SBoNetwork(BlackList, Utils):
status = False status = False
pkg = DialogUtil(data, text, title, backtitle, status).checklist() pkg = DialogUtil(data, text, title, backtitle, status).checklist()
if pkg and len(pkg) > 1: if pkg and len(pkg) > 1:
raise SystemExit("\nslpkg: Error: Choose only one package") os.system("clear")
raise SystemExit("\nslpkg: Error: Choose only one package\n")
if pkg is None: if pkg is None:
raise SystemExit(1) raise SystemExit(1)
self.name = "".join(pkg) self.name = "".join(pkg)
@ -341,7 +342,8 @@ class SBoNetwork(BlackList, Utils):
if self.FAULT: if self.FAULT:
print() print()
self.msg.template(78) self.msg.template(78)
print(f"| Package {self.prgnam} {self.red} {self.FAULT} {self.endc}") print(f"| Package {self.prgnam} {self.red} {self.FAULT} "
f"{self.endc}")
self.msg.template(78) self.msg.template(78)
else: else:
sources = [] sources = []

View file

@ -82,16 +82,17 @@ class QueuePkgs(Utils):
def listed(self): def listed(self):
"""Print packages from queue """Print packages from queue
""" """
print("Packages in the queue:\n") print("Packages in the queue:")
for pkg in self.packages(): for pkg in self.packages():
print(f"{self.green}{pkg}{self.endc}") print(f"{self.green}{pkg}{self.endc}")
print()
def add(self, pkgs): def add(self, pkgs):
"""Add packages in queue if not exist """Add packages in queue if not exist
""" """
queue_list = list(self.packages()) queue_list = list(self.packages())
pkgs = list(OrderedDict.fromkeys(pkgs)) pkgs = list(OrderedDict.fromkeys(pkgs))
print("Add packages in the queue:\n") print("Add packages in the queue:")
with open(self.queue_list, "a") as queue: with open(self.queue_list, "a") as queue:
for pkg in pkgs: for pkg in pkgs:
find = sbo_search_pkg(pkg) find = sbo_search_pkg(pkg)
@ -100,24 +101,30 @@ class QueuePkgs(Utils):
queue.write(pkg + "\n") queue.write(pkg + "\n")
else: else:
print(f"{self.red}{pkg}{self.endc}") print(f"{self.red}{pkg}{self.endc}")
print()
def remove(self, pkgs): def remove(self, pkgs):
"""Remove packages from queue """Remove packages from queue
""" """
print("Remove packages from the queue:\n") print("Remove packages from the queue:")
with open(self.queue_list, "w") as queue: with open(self.queue_list, "w") as queue:
for line in self.queued.splitlines(): for line in self.queued.splitlines():
if line not in pkgs: if line not in pkgs:
queue.write(line + "\n") queue.write(line + "\n")
else: else:
print(f"{self.red}{line}{self.endc}") print(f"{self.red}{line}{self.endc}")
print()
def build(self): def build(self):
"""Build packages from queue """Build packages from queue
""" """
sources = []
packages = list(self.packages()) packages = list(self.packages())
if packages: if packages:
for pkg in packages: for pkg in packages:
if pkg not in SBoGrep(pkg).names():
raise SystemExit(f"\nPackage '{pkg}' was not found in "
f"the SBo repository\n")
if not os.path.exists(self.meta.build_path): if not os.path.exists(self.meta.build_path):
os.mkdir(self.meta.build_path) os.mkdir(self.meta.build_path)
if not os.path.exists(self._SOURCES): if not os.path.exists(self._SOURCES):
@ -125,7 +132,6 @@ class QueuePkgs(Utils):
sbo_url = sbo_search_pkg(pkg) sbo_url = sbo_search_pkg(pkg)
sbo_dwn = SBoLink(sbo_url).tar_gz() sbo_dwn = SBoLink(sbo_url).tar_gz()
source_dwn = SBoGrep(pkg).source().split() source_dwn = SBoGrep(pkg).source().split()
sources = []
os.chdir(self.meta.build_path) os.chdir(self.meta.build_path)
script = sbo_dwn.split("/")[-1] script = sbo_dwn.split("/")[-1]
Download(self.meta.build_path, sbo_dwn.split(), Download(self.meta.build_path, sbo_dwn.split(),

View file

@ -166,7 +166,7 @@ class SBoInstall(BlackList, Utils):
self.continue_to_install() self.continue_to_install()
else: else:
self.msg.not_found(self.is_upgrade) self.msg.not_found(self.is_upgrade)
raise SystemExit(1) raise SystemExit()
def case_insensitive(self): def case_insensitive(self):
"""Matching packages distinguish between uppercase and """Matching packages distinguish between uppercase and

View file

@ -53,6 +53,6 @@ def choose_upg(packages):
if name in packages: if name in packages:
selected_packages.append(name) selected_packages.append(name)
if not selected_packages: if not selected_packages:
raise SystemExit() raise SystemExit(1)
print() print()
return selected_packages return selected_packages