[modules/packages] Added support for Portage and Entropy

This commit is contained in:
skullbocks 2015-06-08 18:56:24 +02:00
parent 55476ae6fc
commit 57406f3bc9
3 changed files with 16 additions and 6 deletions

View File

@ -40,7 +40,7 @@ macro( find_boost_python3 boost_version python_version found_var )
break()
endif()
endforeach()
# The following loop chage the searched name for Gentoo based distributions
# The following loop changes the searched name for Gentoo based distributions
# turns "3.4.123abc" into "3.4"
string( REGEX REPLACE "([0-9]+)\\.([0-9]+)\\..*" "\\1.\\2" _fbp_python_short_version ${python_version} )
foreach( _fbp_name ${CALAMARES_BOOST_PYTHON3_COMPONENT} python-${_fbp_python_short_version} )

View File

@ -55,6 +55,10 @@ class PackageManager:
elif self.backend == "pacman":
pacman_flags = "-U" if from_local else "-Sy"
check_chroot_call(["pacman", pacman_flags, "--noconfirm"] + pkgs)
elif self.backend == "portage":
check_chroot_call(["emerge", "-v"] + pkgs)
elif self.backend == "entropy":
check_chroot_call(["equo", "i"] + pkgs)
def remove(self, pkgs):
""" Removes packages.
@ -78,6 +82,10 @@ class PackageManager:
check_chroot_call(["apt-get", "--purge", "-q", "-y", "autoremove"])
elif self.backend == "pacman":
check_chroot_call(["pacman", "-Rs", "--noconfirm"] + pkgs)
elif self.backend == "portage":
check_chroot_call(["emerge", "-C"] + pkgs)
elif self.backend == "entropy":
check_chroot_call(["equo", "rm"] + pkgs)
def run_operations(pkgman, entry):
@ -102,7 +110,7 @@ def run():
:return:
"""
backend = libcalamares.job.configuration.get("backend")
if backend not in ("packagekit", "zypp", "yum", "dnf", "urpmi", "apt", "pacman"):
if backend not in ("packagekit", "zypp", "yum", "dnf", "urpmi", "apt", "pacman", "portage", "entropy"):
return ("Bad backend", "backend=\"{}\"".format(backend))
pkgman = PackageManager(backend)

View File

@ -8,6 +8,8 @@
# - urpmi - Mandriva package manager
# - apt - APT frontend for DEB and RPM
# - pacman - Pacman
# - portage - Gentoo package manager
# - entropy - Sabayon package manager
#
backend: packagekit
#