X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=src%2Fnepi%2Fresources%2Flinux%2Frpmfuncs.py;h=35aeb612c5b721911ee1a6ab2d69da3e5a2cd8f6;hb=5a00a5d04a1d1ecd4cafd5582f7747f84985cd3f;hp=e42e7b85819219db1b29f44b7a43d8727c9ca821;hpb=6a8c7da45f7d745ea47c5020b13dfb8ada0931db;p=nepi.git diff --git a/src/nepi/resources/linux/rpmfuncs.py b/src/nepi/resources/linux/rpmfuncs.py index e42e7b85..35aeb612 100644 --- a/src/nepi/resources/linux/rpmfuncs.py +++ b/src/nepi/resources/linux/rpmfuncs.py @@ -19,6 +19,8 @@ RPM_FUSION_URL = 'http://download1.rpmfusion.org/free/fedora/rpmfusion-free-release-stable.noarch.rpm' RPM_FUSION_URL_F12 = 'http://download1.rpmfusion.org/free/fedora/releases/12/Everything/x86_64/os/rpmfusion-free-release-12-1.noarch.rpm' +RPM_FUSION_URL_F14 = 'http://download1.rpmfusion.org/free/fedora/releases/14/Everything/x86_64/os/rpmfusion-free-release-14-0.4.noarch.rpm' + # TODO: Investigate using http://nixos.org/nix/ @@ -26,37 +28,42 @@ def install_packages_command(os, packages): if not isinstance(packages, list): packages = [packages] - cmd = "( %s )" % install_rpmfusion_command(os) - for p in packages: - cmd += " ; ( rpm -q %(package)s || sudo -S yum -y install %(package)s ) " % { - 'package': p} + cmd = install_rpmfusion_command(os) + if cmd: cmd += " ; " + cmd += " && ".join(map(lambda p: + " { rpm -q %(package)s || sudo -S yum -y install --nogpgcheck %(package)s ; } " % { + 'package': p}, packages)) - #cmd = ((rpm -q rpmfusion-free-release || sudo -s rpm -i ...) ; (rpm -q vim || sudo yum -y install vim)) - return " ( %s )" % cmd + #cmd = { rpm -q rpmfusion-free-release || sudo -s rpm -i ... ; } && { rpm -q vim || sudo yum -y install vim ; } && .. + return cmd def remove_packages_command(os, packages): if not isinstance(packages, list): packages = [packages] - cmd = "" - for p in packages: - cmd += " ( rpm -q %(package)s && sudo -S yum -y remove %(package)s ) ; " % { - 'package': p} - - #cmd = (rpm -q vim || sudo yum -y remove vim) ; (...) + cmd = " && ".join(map(lambda p: + " { rpm -q %(package)s && sudo -S yum -y remove %(package)s ; } " % { + 'package': p}, packages)) + + #cmd = { rpm -q vim && sudo yum -y remove vim ; } && .. return cmd def install_rpmfusion_command(os): from nepi.resources.linux.node import OSType - cmd = "rpm -q rpmfusion-free-release || sudo -S rpm -i %(package)s" + cmd = " { rpm -q rpmfusion-free-release || sudo -S rpm -i %(package)s ; } " if os in [OSType.FEDORA, OSType.FEDORA_12]: + # For f12 cmd = cmd % {'package': RPM_FUSION_URL_F12} elif os == OSType.FEDORA_14: - # This one works for f13+ + # For f14 + cmd = cmd % {'package': RPM_FUSION_URL_F14} + elif os == OSType.FEDORA: + # For f14+ cmd = cmd % {'package': RPM_FUSION_URL} else: + # Fedora 8 is unmaintained cmd = "" return cmd