Commit b7971a42 by Michael DeHaan

Merge pull request #4931 from mscherer/urpmi_fix

Various fix for the urpmi module
parents 1e460934 0d8b81cd
......@@ -76,11 +76,18 @@ import json
import shlex
import os
import sys
try:
import rpm
USE_PYTHON = True
except ImportError:
USE_PYTHON = False
URPMI_PATH = '/usr/sbin/urpmi'
URPME_PATH = '/usr/sbin/urpme'
def query_package(module, name):
if USE_PYTHON:
return rpm.TransactionSet().dbMatch(rpm.RPMTAG_NAME, name).count() != 0
# rpm -q returns 0 if the package is installed,
# 1 if it is not installed
......@@ -90,6 +97,15 @@ def query_package(module, name):
else:
return False
def query_package_provides(module, name):
if USE_PYTHON:
return rpm.TransactionSet().dbMatch(rpm.RPMTAG_PROVIDES, name).count() != 0
# rpm -q returns 0 if the package is installed,
# 1 if it is not installed
rc = os.system("rpm -q --provides %s >/dev/null" % (name))
return rc == 0
def update_package_db(module):
rc = os.system("urpmi.update -a -q")
......@@ -125,7 +141,8 @@ def install_packages(module, pkgspec, force=True, no_suggests=True):
packages = ""
for package in pkgspec:
packages += "'%s' " % package
if not query_package_provides(module, package):
packages += "'%s' " % package
if len(packages) != 0:
if no_suggests:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment