From 7c72bf73b8064da0f98fe83a549ddbb1b82d4dea Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Mon, 8 Sep 2008 11:17:17 +0000 Subject: yum: Add yum-install-recommends.py script to handle installing Recommends git-svn-id: https://svn.o-hand.com/repos/poky/trunk@5157 311d38ba-8fff-0310-9ca6-ca027cbcb966 --- .../yum/yum-native/yum-install-recommends.py | 39 ++++++++++++++++++++++ meta/packages/yum/yum-native_3.2.18.bb | 4 ++- 2 files changed, 42 insertions(+), 1 deletion(-) create mode 100755 meta/packages/yum/yum-native/yum-install-recommends.py (limited to 'meta') diff --git a/meta/packages/yum/yum-native/yum-install-recommends.py b/meta/packages/yum/yum-native/yum-install-recommends.py new file mode 100755 index 0000000000..64716f2c3e --- /dev/null +++ b/meta/packages/yum/yum-native/yum-install-recommends.py @@ -0,0 +1,39 @@ +#!/usr/bin/env python +import os, sys + +root = sys.argv[1] +installcmd = sys.argv[2] + +# +# Take an rpm image and look through for Recommends:. For each recommends +# found, try and install any matching packages including any Recommends for +# packages installed by us. +# + + +def get_recommends(): + deps = [] + output = os.popen("rpm --root %s -aq --recommends" % (root)) + lines = output.readlines() + for line in lines: + line = line.replace("(none)","") + if line: + deps.append(line.split()[0]) + return deps + +processed = [] + +while True: + toinstall = [] + recommends = set(get_recommends()) + for item in recommends: + if item not in processed: + toinstall.append(item) + if len(toinstall) != 0: + print "Installing %s" % " ".join(toinstall) + os.system("%s %s" % (installcmd, " ".join(toinstall))) + else: + break + processed.extend(toinstall) + + diff --git a/meta/packages/yum/yum-native_3.2.18.bb b/meta/packages/yum/yum-native_3.2.18.bb index 76e92b34a9..60dafe3265 100644 --- a/meta/packages/yum/yum-native_3.2.18.bb +++ b/meta/packages/yum/yum-native_3.2.18.bb @@ -3,8 +3,9 @@ HOMEPAGE = "http://linux.duke.edu/projects/yum/" SRC_URI = "http://linux.duke.edu/projects/yum/download/3.2/yum-${PV}.tar.gz \ file://hacks.patch;patch=1 \ file://paths.patch;patch=1 \ + file://yum-install-recommends.py \ file://extract-postinst.awk" -PR = "r4" +PR = "r5" DEPENDS = "rpm-native python-native python-iniparse-native python-urlgrabber-native yum-metadata-parser-native libxml2-native" @@ -20,4 +21,5 @@ do_compile_append () { do_install_append () { install -d ${STAGING_BINDIR}/ install ${WORKDIR}/extract-postinst.awk ${STAGING_BINDIR}/ + install ${WORKDIR}/yum-install-recommends.py ${STAGING_BINDIR}/ } -- cgit v1.2.3-54-g00ecf