diff options
author | Richard Purdie <richard@openedhand.com> | 2008-09-08 11:17:17 +0000 |
---|---|---|
committer | Richard Purdie <richard@openedhand.com> | 2008-09-08 11:17:17 +0000 |
commit | 7c72bf73b8064da0f98fe83a549ddbb1b82d4dea (patch) | |
tree | 40b859ffe969de131570fdd2f78bafef114f9da7 /meta/packages/yum | |
parent | da34e322e9ec0025c7e32fc5715ac7e94aa3f045 (diff) | |
download | poky-7c72bf73b8064da0f98fe83a549ddbb1b82d4dea.tar.gz |
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
Diffstat (limited to 'meta/packages/yum')
-rwxr-xr-x | meta/packages/yum/yum-native/yum-install-recommends.py | 39 | ||||
-rw-r--r-- | meta/packages/yum/yum-native_3.2.18.bb | 4 |
2 files changed, 42 insertions, 1 deletions
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 @@ | |||
1 | #!/usr/bin/env python | ||
2 | import os, sys | ||
3 | |||
4 | root = sys.argv[1] | ||
5 | installcmd = sys.argv[2] | ||
6 | |||
7 | # | ||
8 | # Take an rpm image and look through for Recommends:. For each recommends | ||
9 | # found, try and install any matching packages including any Recommends for | ||
10 | # packages installed by us. | ||
11 | # | ||
12 | |||
13 | |||
14 | def get_recommends(): | ||
15 | deps = [] | ||
16 | output = os.popen("rpm --root %s -aq --recommends" % (root)) | ||
17 | lines = output.readlines() | ||
18 | for line in lines: | ||
19 | line = line.replace("(none)","") | ||
20 | if line: | ||
21 | deps.append(line.split()[0]) | ||
22 | return deps | ||
23 | |||
24 | processed = [] | ||
25 | |||
26 | while True: | ||
27 | toinstall = [] | ||
28 | recommends = set(get_recommends()) | ||
29 | for item in recommends: | ||
30 | if item not in processed: | ||
31 | toinstall.append(item) | ||
32 | if len(toinstall) != 0: | ||
33 | print "Installing %s" % " ".join(toinstall) | ||
34 | os.system("%s %s" % (installcmd, " ".join(toinstall))) | ||
35 | else: | ||
36 | break | ||
37 | processed.extend(toinstall) | ||
38 | |||
39 | |||
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/" | |||
3 | SRC_URI = "http://linux.duke.edu/projects/yum/download/3.2/yum-${PV}.tar.gz \ | 3 | SRC_URI = "http://linux.duke.edu/projects/yum/download/3.2/yum-${PV}.tar.gz \ |
4 | file://hacks.patch;patch=1 \ | 4 | file://hacks.patch;patch=1 \ |
5 | file://paths.patch;patch=1 \ | 5 | file://paths.patch;patch=1 \ |
6 | file://yum-install-recommends.py \ | ||
6 | file://extract-postinst.awk" | 7 | file://extract-postinst.awk" |
7 | PR = "r4" | 8 | PR = "r5" |
8 | 9 | ||
9 | DEPENDS = "rpm-native python-native python-iniparse-native python-urlgrabber-native yum-metadata-parser-native libxml2-native" | 10 | DEPENDS = "rpm-native python-native python-iniparse-native python-urlgrabber-native yum-metadata-parser-native libxml2-native" |
10 | 11 | ||
@@ -20,4 +21,5 @@ do_compile_append () { | |||
20 | do_install_append () { | 21 | do_install_append () { |
21 | install -d ${STAGING_BINDIR}/ | 22 | install -d ${STAGING_BINDIR}/ |
22 | install ${WORKDIR}/extract-postinst.awk ${STAGING_BINDIR}/ | 23 | install ${WORKDIR}/extract-postinst.awk ${STAGING_BINDIR}/ |
24 | install ${WORKDIR}/yum-install-recommends.py ${STAGING_BINDIR}/ | ||
23 | } | 25 | } |