mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2025-01-19 10:27:07 +01:00
added read file.pkg instead [package...]
This commit is contained in:
parent
46ec3e8300
commit
c1dd7751fc
4 changed files with 53 additions and 19 deletions
|
@ -3,6 +3,7 @@ Version 2.2.1
|
||||||
|
|
||||||
[Feature] - Added support multipackages.
|
[Feature] - Added support multipackages.
|
||||||
- Added passing variables to the script.
|
- Added passing variables to the script.
|
||||||
|
- Added read file.pkg instead [package...]
|
||||||
|
|
||||||
[Updated] - Fix [key error] when you enter wrong name repository as default.
|
[Updated] - Fix [key error] when you enter wrong name repository as default.
|
||||||
- Rename BUILD variable to BUILD_PATH in configuration file slpkg.conf.
|
- Rename BUILD variable to BUILD_PATH in configuration file slpkg.conf.
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
import sys
|
import sys
|
||||||
import getpass
|
import getpass
|
||||||
|
|
||||||
|
from utils import Utils
|
||||||
from messages import Msg
|
from messages import Msg
|
||||||
from desc import PkgDesc
|
from desc import PkgDesc
|
||||||
from config import Config
|
from config import Config
|
||||||
|
@ -92,11 +93,25 @@ def main():
|
||||||
# '-n', '-i', '-u', '-o', '-r', '-d'
|
# '-n', '-i', '-u', '-o', '-r', '-d'
|
||||||
# ]
|
# ]
|
||||||
|
|
||||||
|
if (args[0] in ['-f', '-i', '-u', '-o', '-r', '-d'] and
|
||||||
|
args[1].endswith('.pkg')):
|
||||||
|
packages = Utils().read_file_pkg(args[1])
|
||||||
|
elif args[0] in ['-s'] and args[2].endswith('.pkg'):
|
||||||
|
packages = Utils().read_file_pkg(args[2])
|
||||||
|
else:
|
||||||
|
packages = args[1:]
|
||||||
|
|
||||||
|
if args[0] in ['-q', '-b'] and args[1].endswith('.pkg'):
|
||||||
|
packages = Utils().read_file_pkg(args[1])
|
||||||
|
else:
|
||||||
|
packages = args[1:-1]
|
||||||
|
|
||||||
without_repos = [
|
without_repos = [
|
||||||
'-h', '--help', '-v', '-a', '-b',
|
'-h', '--help', '-v', '-a', '-b',
|
||||||
'-q', '-g', '-f', '-n', '-i', '-u',
|
'-q', '-g', '-f', '-n', '-i', '-u',
|
||||||
'-o', '-r', '-d'
|
'-o', '-r', '-d'
|
||||||
]
|
]
|
||||||
|
""" COMMANDS """
|
||||||
|
|
||||||
if len(args) == 1 and args[0] == 'update':
|
if len(args) == 1 and args[0] == 'update':
|
||||||
Update().repository()
|
Update().repository()
|
||||||
|
@ -136,6 +151,9 @@ def main():
|
||||||
elif (len(args) == 2 and args[0] == 'repo-info' and
|
elif (len(args) == 2 and args[0] == 'repo-info' and
|
||||||
args[1] not in RepoList().all_repos):
|
args[1] not in RepoList().all_repos):
|
||||||
usage(args[1])
|
usage(args[1])
|
||||||
|
|
||||||
|
""" ARGUMENTS """
|
||||||
|
|
||||||
if len(args) == 3 and args[0] == '-a':
|
if len(args) == 3 and args[0] == '-a':
|
||||||
BuildPackage(args[1], args[2:], _m.path).build()
|
BuildPackage(args[1], args[2:], _m.path).build()
|
||||||
elif (len(args) == 3 and args[0] == '-l' and args[1] in _m.repositories):
|
elif (len(args) == 3 and args[0] == '-l' and args[1] in _m.repositories):
|
||||||
|
@ -160,9 +178,9 @@ def main():
|
||||||
usage(args[1])
|
usage(args[1])
|
||||||
elif len(args) >= 3 and args[0] == '-s':
|
elif len(args) >= 3 and args[0] == '-s':
|
||||||
if args[1] in _m.repositories and args[1] not in ['sbo']:
|
if args[1] in _m.repositories and args[1] not in ['sbo']:
|
||||||
Case(args[2:]).binary_install(args[1])
|
Case(packages).binary_install(args[1])
|
||||||
elif args[1] == 'sbo':
|
elif args[1] == 'sbo':
|
||||||
Case(args[2:]).sbo_install()
|
Case(packages).sbo_install()
|
||||||
else:
|
else:
|
||||||
usage(args[1])
|
usage(args[1])
|
||||||
elif (len(args) == 3 and args[0] == '-t' and args[1] in _m.repositories):
|
elif (len(args) == 3 and args[0] == '-t' and args[1] in _m.repositories):
|
||||||
|
@ -172,15 +190,15 @@ def main():
|
||||||
elif len(args) == 2 and args[0] == '-b' and args[1] == '--list':
|
elif len(args) == 2 and args[0] == '-b' and args[1] == '--list':
|
||||||
blacklist.listed()
|
blacklist.listed()
|
||||||
elif len(args) > 2 and args[0] == '-b' and args[-1] == '--add':
|
elif len(args) > 2 and args[0] == '-b' and args[-1] == '--add':
|
||||||
blacklist.add(args[1:-1])
|
blacklist.add(packages)
|
||||||
elif len(args) > 2 and args[0] == '-b' and args[-1] == '--remove':
|
elif len(args) > 2 and args[0] == '-b' and args[-1] == '--remove':
|
||||||
blacklist.remove(args[1:-1])
|
blacklist.remove(packages)
|
||||||
elif len(args) == 2 and args[0] == '-q' and args[1] == '--list':
|
elif len(args) == 2 and args[0] == '-q' and args[1] == '--list':
|
||||||
queue.listed()
|
queue.listed()
|
||||||
elif len(args) > 2 and args[0] == '-q' and args[-1] == '--add':
|
elif len(args) > 2 and args[0] == '-q' and args[-1] == '--add':
|
||||||
queue.add(args[1:-1])
|
queue.add(packages)
|
||||||
elif len(args) > 2 and args[0] == '-q' and args[-1] == '--remove':
|
elif len(args) > 2 and args[0] == '-q' and args[-1] == '--remove':
|
||||||
queue.remove(args[1:-1])
|
queue.remove(packages)
|
||||||
elif len(args) == 2 and args[0] == '-q' and args[1] == '--build':
|
elif len(args) == 2 and args[0] == '-q' and args[1] == '--build':
|
||||||
queue.build()
|
queue.build()
|
||||||
elif len(args) == 2 and args[0] == '-q' and args[1] == '--install':
|
elif len(args) == 2 and args[0] == '-q' and args[1] == '--install':
|
||||||
|
@ -189,15 +207,15 @@ def main():
|
||||||
queue.build()
|
queue.build()
|
||||||
queue.install()
|
queue.install()
|
||||||
elif len(args) > 1 and args[0] == '-i':
|
elif len(args) > 1 and args[0] == '-i':
|
||||||
PackageManager(args[1:]).install()
|
PackageManager(packages).install()
|
||||||
elif len(args) > 1 and args[0] == '-u':
|
elif len(args) > 1 and args[0] == '-u':
|
||||||
PackageManager(args[1:]).upgrade()
|
PackageManager(packages).upgrade()
|
||||||
elif len(args) > 1 and args[0] == '-o':
|
elif len(args) > 1 and args[0] == '-o':
|
||||||
PackageManager(args[1:]).reinstall()
|
PackageManager(packages).reinstall()
|
||||||
elif len(args) > 1 and args[0] == '-r':
|
elif len(args) > 1 and args[0] == '-r':
|
||||||
PackageManager(args[1:]).remove()
|
PackageManager(packages).remove()
|
||||||
elif len(args) > 1 and args[0] == '-f':
|
elif len(args) > 1 and args[0] == '-f':
|
||||||
PackageManager(args[1:]).find()
|
PackageManager(packages).find()
|
||||||
elif len(args) == 3 and args[0] == '-p' and args[1] in _m.repositories:
|
elif len(args) == 3 and args[0] == '-p' and args[1] in _m.repositories:
|
||||||
PkgDesc(args[2], args[1], '').view()
|
PkgDesc(args[2], args[1], '').view()
|
||||||
elif len(args) == 4 and args[0] == '-p' and args[3].startswith('--color='):
|
elif len(args) == 4 and args[0] == '-p' and args[3].startswith('--color='):
|
||||||
|
@ -208,7 +226,7 @@ def main():
|
||||||
else:
|
else:
|
||||||
usage(args[1])
|
usage(args[1])
|
||||||
elif len(args) > 1 and args[0] == '-d':
|
elif len(args) > 1 and args[0] == '-d':
|
||||||
PackageManager(args[1:]).display()
|
PackageManager(packages).display()
|
||||||
elif len(args) == 2 and args[0] == '-g' and args[1].startswith('--config'):
|
elif len(args) == 2 and args[0] == '-g' and args[1].startswith('--config'):
|
||||||
editor = args[1][len('--config='):]
|
editor = args[1][len('--config='):]
|
||||||
if args[1] == '--config':
|
if args[1] == '--config':
|
||||||
|
|
|
@ -52,7 +52,7 @@ class PackageManager(object):
|
||||||
pkg), shell=True))
|
pkg), shell=True))
|
||||||
print("Completed!\n")
|
print("Completed!\n")
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError:
|
||||||
self.not_found("Can't install", self.binary, pkg)
|
self._not_found("Can't install", self.binary, pkg)
|
||||||
|
|
||||||
def upgrade(self):
|
def upgrade(self):
|
||||||
'''
|
'''
|
||||||
|
@ -64,7 +64,7 @@ class PackageManager(object):
|
||||||
"{0}".format(pkg), shell=True))
|
"{0}".format(pkg), shell=True))
|
||||||
print("Completed!\n")
|
print("Completed!\n")
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError:
|
||||||
self.not_found("Can't upgrade", self.binary, pkg)
|
self._not_found("Can't upgrade", self.binary, pkg)
|
||||||
|
|
||||||
def reinstall(self):
|
def reinstall(self):
|
||||||
'''
|
'''
|
||||||
|
@ -76,7 +76,7 @@ class PackageManager(object):
|
||||||
"upgradepkg --reinstall {0}".format(pkg), shell=True))
|
"upgradepkg --reinstall {0}".format(pkg), shell=True))
|
||||||
print("Completed!\n")
|
print("Completed!\n")
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError:
|
||||||
self.not_found("Can't reinstall", self.binary, pkg)
|
self._not_found("Can't reinstall", self.binary, pkg)
|
||||||
|
|
||||||
def _not_found(self, message, binary, pkg):
|
def _not_found(self, message, binary, pkg):
|
||||||
if len(binary) > 1:
|
if len(binary) > 1:
|
||||||
|
@ -91,7 +91,7 @@ class PackageManager(object):
|
||||||
'''
|
'''
|
||||||
dep_path = _m.log_path + "dep/"
|
dep_path = _m.log_path + "dep/"
|
||||||
dependencies, rmv_list = [], []
|
dependencies, rmv_list = [], []
|
||||||
removed = self._view_removed(self.binary)
|
removed = self._view_removed()
|
||||||
if not removed:
|
if not removed:
|
||||||
print("") # new line at end
|
print("") # new line at end
|
||||||
else:
|
else:
|
||||||
|
@ -143,14 +143,14 @@ class PackageManager(object):
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
return remove_dep
|
return remove_dep
|
||||||
|
|
||||||
def _view_removed(self, binary):
|
def _view_removed(self):
|
||||||
'''
|
'''
|
||||||
View packages before removed
|
View packages before removed
|
||||||
'''
|
'''
|
||||||
removed = []
|
removed = []
|
||||||
print("\nPackages with name matching [ {0}{1}{2} ]\n".format(
|
print("\nPackages with name matching [ {0}{1}{2} ]\n".format(
|
||||||
_m.color['CYAN'], ", ".join(binary), _m.color['ENDC']))
|
_m.color['CYAN'], ", ".join(self.binary), _m.color['ENDC']))
|
||||||
for pkg in binary:
|
for pkg in self.binary:
|
||||||
pkgs = find_package(pkg + _m.sp, _m.pkg_path)
|
pkgs = find_package(pkg + _m.sp, _m.pkg_path)
|
||||||
if pkgs:
|
if pkgs:
|
||||||
print("[ {0}delete{1} ] --> {2}".format(
|
print("[ {0}delete{1} ] --> {2}".format(
|
||||||
|
|
|
@ -71,3 +71,18 @@ class Utils(object):
|
||||||
if os.path.isfile(path + pkg):
|
if os.path.isfile(path + pkg):
|
||||||
downloaded.append(pkg)
|
downloaded.append(pkg)
|
||||||
return downloaded
|
return downloaded
|
||||||
|
|
||||||
|
def read_file_pkg(self, file_pkg):
|
||||||
|
'''
|
||||||
|
Return packages from file
|
||||||
|
'''
|
||||||
|
packages = []
|
||||||
|
if os.path.isfile(file_pkg):
|
||||||
|
packages = []
|
||||||
|
r_file = self.read_file(file_pkg)
|
||||||
|
for pkg in r_file.splitlines():
|
||||||
|
packages.append(pkg)
|
||||||
|
else:
|
||||||
|
print("\nThe '{0}' file not found\n".format(
|
||||||
|
file_pkg.split('/')[-1]))
|
||||||
|
return filter(lambda x: x != '', packages)
|
||||||
|
|
Loading…
Reference in a new issue