mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2025-01-18 10:26:29 +01:00
Fixed complexity
This commit is contained in:
parent
2c387c06ba
commit
cf17321c01
1 changed files with 103 additions and 88 deletions
193
slpkg/main.py
193
slpkg/main.py
|
@ -21,52 +21,104 @@ from slpkg.update_repository import UpdateRepository
|
||||||
class Argparse:
|
class Argparse:
|
||||||
args: list
|
args: list
|
||||||
|
|
||||||
def flags(self):
|
def __post_init__(self):
|
||||||
self.flags = []
|
self.flag()
|
||||||
yes = '--yes'
|
self.check = Check()
|
||||||
jobs = '--jobs'
|
|
||||||
resolve_off = '--resolve-off'
|
|
||||||
reinstall = '--reinstall'
|
|
||||||
|
|
||||||
if yes in self.args:
|
|
||||||
self.args.remove(yes)
|
|
||||||
self.flags.append(yes)
|
|
||||||
|
|
||||||
if jobs in self.args:
|
|
||||||
self.args.remove(jobs)
|
|
||||||
self.flags.append(jobs)
|
|
||||||
|
|
||||||
if resolve_off in self.args:
|
|
||||||
self.args.remove(resolve_off)
|
|
||||||
self.flags.append(resolve_off)
|
|
||||||
|
|
||||||
if reinstall in self.args:
|
|
||||||
self.args.remove(reinstall)
|
|
||||||
self.flags.append(reinstall)
|
|
||||||
|
|
||||||
def command(self):
|
|
||||||
|
|
||||||
self.flags()
|
|
||||||
check = Check()
|
|
||||||
|
|
||||||
if len(self.args) <= 0:
|
if len(self.args) <= 0:
|
||||||
usage(1)
|
usage(1)
|
||||||
|
|
||||||
if len(self.args) == 1:
|
def flag(self):
|
||||||
if self.args[0] in ['--help', '-h']:
|
self.flags = []
|
||||||
usage(0)
|
|
||||||
|
|
||||||
if self.args[0] in ['--version', '-v']:
|
options = ['--yes',
|
||||||
|
'--jobs',
|
||||||
|
'--resolve-off',
|
||||||
|
'--reinstall'
|
||||||
|
]
|
||||||
|
|
||||||
|
for option in options:
|
||||||
|
if option in self.args:
|
||||||
|
self.args.remove(option)
|
||||||
|
self.flags.append(option)
|
||||||
|
|
||||||
|
def help(self):
|
||||||
|
if len(self.args) == 1:
|
||||||
|
usage(0)
|
||||||
|
usage(1)
|
||||||
|
|
||||||
|
def version(self):
|
||||||
|
if len(self.args) == 1:
|
||||||
version = Version()
|
version = Version()
|
||||||
version.view()
|
version.view()
|
||||||
raise SystemExit()
|
raise SystemExit()
|
||||||
|
usage(1)
|
||||||
|
|
||||||
if self.args[0] == 'clean-logs':
|
def update(self):
|
||||||
|
if len(self.args) == 1:
|
||||||
|
update = UpdateRepository()
|
||||||
|
update.sbo()
|
||||||
|
raise SystemExit()
|
||||||
|
usage(1)
|
||||||
|
|
||||||
|
def build(self):
|
||||||
|
if len(self.args) >= 2:
|
||||||
|
packages = list(set(self.args[1:]))
|
||||||
|
|
||||||
|
self.check.exists(packages)
|
||||||
|
self.check.unsupported(packages)
|
||||||
|
|
||||||
|
build = Slackbuilds(packages, self.flags, False)
|
||||||
|
build.execute()
|
||||||
|
raise SystemExit()
|
||||||
|
usage(1)
|
||||||
|
|
||||||
|
def install(self):
|
||||||
|
if len(self.args) >= 2:
|
||||||
|
packages = list(set(self.args[1:]))
|
||||||
|
|
||||||
|
self.check.exists(packages)
|
||||||
|
self.check.unsupported(packages)
|
||||||
|
|
||||||
|
install = Slackbuilds(packages, self.flags, True)
|
||||||
|
install.execute()
|
||||||
|
raise SystemExit()
|
||||||
|
usage(1)
|
||||||
|
|
||||||
|
def remove(self):
|
||||||
|
if len(self.args) >= 2:
|
||||||
|
packages = list(set(self.args[1:]))
|
||||||
|
packages = self.check.blacklist(packages)
|
||||||
|
|
||||||
|
self.check.installed(packages)
|
||||||
|
|
||||||
|
remove = RemovePackages(packages, self.flags)
|
||||||
|
remove.remove()
|
||||||
|
raise SystemExit()
|
||||||
|
usage(1)
|
||||||
|
|
||||||
|
def search(self):
|
||||||
|
# Search package
|
||||||
|
if len(self.args) >= 2:
|
||||||
|
packages = list(set(self.args[1:]))
|
||||||
|
packages = self.check.blacklist(packages)
|
||||||
|
|
||||||
|
self.check.exists(packages)
|
||||||
|
|
||||||
|
search = Search()
|
||||||
|
search.package(packages)
|
||||||
|
raise SystemExit()
|
||||||
|
usage(1)
|
||||||
|
|
||||||
|
def clean_logs(self):
|
||||||
|
if len(self.args) == 1:
|
||||||
logs = CleanLogsDependencies(self.flags)
|
logs = CleanLogsDependencies(self.flags)
|
||||||
logs.clean()
|
logs.clean()
|
||||||
raise SystemExit()
|
raise SystemExit()
|
||||||
|
usage(1)
|
||||||
|
|
||||||
if self.args[0] == 'clean-tmp':
|
def clean_tmp(self):
|
||||||
|
if len(self.args) == 1:
|
||||||
path = Configs.tmp_path
|
path = Configs.tmp_path
|
||||||
tmp_slpkg = Configs.tmp_slpkg
|
tmp_slpkg = Configs.tmp_slpkg
|
||||||
folder = Configs.prog_name
|
folder = Configs.prog_name
|
||||||
|
@ -74,61 +126,6 @@ class Argparse:
|
||||||
utils.remove_folder_if_exists(path, folder)
|
utils.remove_folder_if_exists(path, folder)
|
||||||
utils.create_folder(tmp_slpkg, 'build/')
|
utils.create_folder(tmp_slpkg, 'build/')
|
||||||
raise SystemExit()
|
raise SystemExit()
|
||||||
|
|
||||||
# Update repository
|
|
||||||
if self.args[0] == 'update':
|
|
||||||
update = UpdateRepository()
|
|
||||||
update.sbo()
|
|
||||||
raise SystemExit()
|
|
||||||
|
|
||||||
usage(1)
|
|
||||||
|
|
||||||
if len(self.args) >= 2:
|
|
||||||
# Build slackbuilds
|
|
||||||
if self.args[0] == 'build':
|
|
||||||
packages = list(set(self.args[1:]))
|
|
||||||
|
|
||||||
check.exists(packages)
|
|
||||||
check.unsupported(packages)
|
|
||||||
|
|
||||||
build = Slackbuilds(packages, self.flags, False)
|
|
||||||
build.execute()
|
|
||||||
raise SystemExit()
|
|
||||||
|
|
||||||
# Install packages
|
|
||||||
if self.args[0] == 'install':
|
|
||||||
packages = list(set(self.args[1:]))
|
|
||||||
|
|
||||||
check.exists(packages)
|
|
||||||
check.unsupported(packages)
|
|
||||||
|
|
||||||
install = Slackbuilds(packages, self.flags, True)
|
|
||||||
install.execute()
|
|
||||||
raise SystemExit()
|
|
||||||
|
|
||||||
# Remove packages
|
|
||||||
if self.args[0] == 'remove':
|
|
||||||
packages = list(set(self.args[1:]))
|
|
||||||
packages = check.blacklist(packages)
|
|
||||||
|
|
||||||
check.installed(packages)
|
|
||||||
|
|
||||||
remove = RemovePackages(packages, self.flags)
|
|
||||||
remove.remove()
|
|
||||||
raise SystemExit()
|
|
||||||
|
|
||||||
# Search package
|
|
||||||
if self.args[0] == 'search':
|
|
||||||
packages = list(set(self.args[1:]))
|
|
||||||
packages = check.blacklist(packages)
|
|
||||||
|
|
||||||
check.exists(packages)
|
|
||||||
|
|
||||||
search = Search()
|
|
||||||
search.package(packages)
|
|
||||||
|
|
||||||
raise SystemExit()
|
|
||||||
|
|
||||||
usage(1)
|
usage(1)
|
||||||
|
|
||||||
|
|
||||||
|
@ -137,7 +134,25 @@ def main():
|
||||||
args.pop(0)
|
args.pop(0)
|
||||||
|
|
||||||
argparse = Argparse(args)
|
argparse = Argparse(args)
|
||||||
argparse.command()
|
|
||||||
|
arguments = {
|
||||||
|
'-h': argparse.help,
|
||||||
|
'--help': argparse.help,
|
||||||
|
'-v': argparse.version,
|
||||||
|
'--version': argparse.version,
|
||||||
|
'update': argparse.update,
|
||||||
|
'build': argparse.build,
|
||||||
|
'install': argparse.install,
|
||||||
|
'remove': argparse.remove,
|
||||||
|
'search': argparse.search,
|
||||||
|
'clean-logs': argparse.clean_logs,
|
||||||
|
'clean-tmp': argparse.clean_tmp,
|
||||||
|
}
|
||||||
|
|
||||||
|
try:
|
||||||
|
arguments[args[0]]()
|
||||||
|
except KeyError:
|
||||||
|
usage(1)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
Loading…
Reference in a new issue