[OE-core] [PATCH 2/4] python-smartpm: add ignore-recommends package flag
Paul Eggleton
paul.eggleton at linux.intel.com
Thu Jul 25 17:09:03 UTC 2013
Adds support for a flag that is saved into Smart's configuration against
a package that says it should not be installed if it is only recommended
by a package being installed rather than required. This will enable us
to add BAD_RECOMMENDATIONS support for RPM.
Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
---
.../smart-flag-ignore-recommends.patch | 60 ++++++++++++++++++++++
.../python/python-smartpm_1.4.1.bb | 1 +
2 files changed, 61 insertions(+)
create mode 100644 meta/recipes-devtools/python/python-smartpm/smart-flag-ignore-recommends.patch
diff --git a/meta/recipes-devtools/python/python-smartpm/smart-flag-ignore-recommends.patch b/meta/recipes-devtools/python/python-smartpm/smart-flag-ignore-recommends.patch
new file mode 100644
index 0000000..5d5c6f4
--- /dev/null
+++ b/meta/recipes-devtools/python/python-smartpm/smart-flag-ignore-recommends.patch
@@ -0,0 +1,60 @@
+Add ignore-recommends flag support
+
+Allow configuring recommends on specific packages to be ignored.
+
+Upstream-Status: Pending
+
+Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
+---
+ smart/commands/flag.py | 3 +++
+ smart/transaction.py | 7 ++++++-
+ 2 files changed, 9 insertions(+), 1 deletion(-)
+
+diff --git a/smart/commands/flag.py b/smart/commands/flag.py
+index 8b90496..191bb11 100644
+--- a/smart/commands/flag.py
++++ b/smart/commands/flag.py
+@@ -47,6 +47,9 @@ Currently known flags are:
+ multi-version - Flagged packages may have more than one version
+ installed in the system at the same time
+ (backend dependent).
++ ignore-recommends - Flagged packages will not be installed, if
++ they are only recommended by a package to be
++ installed rather than required.
+
+ security - Flagged packages are updates for security errata.
+ bugfix - Flagged packages are updates for bugfix errata.
+diff --git a/smart/transaction.py b/smart/transaction.py
+index dd9aa38..38eabae 100644
+--- a/smart/transaction.py
++++ b/smart/transaction.py
+@@ -596,12 +596,17 @@ class Transaction(object):
+ # Install packages required by this one.
+ for req in pkg.requires + pkg.recommends:
+
++ reqrequired = req in pkg.requires
++
+ # Check if someone is already providing it.
+ prvpkgs = {}
+ lockedpkgs = {}
+ found = False
+ for prv in req.providedby:
+ for prvpkg in prv.packages:
++ if not reqrequired:
++ if pkgconf.testFlag("ignore-recommends", prvpkg):
++ continue
+ if isinst(prvpkg):
+ found = True
+ break
+@@ -620,7 +625,7 @@ class Transaction(object):
+
+ if not prvpkgs:
+ # No packages provide it at all. Give up.
+- if req in pkg.requires:
++ if reqrequired:
+ reasons = []
+ for prv in req.providedby:
+ for prvpkg in prv.packages:
+--
+1.8.1.2
+
diff --git a/meta/recipes-devtools/python/python-smartpm_1.4.1.bb b/meta/recipes-devtools/python/python-smartpm_1.4.1.bb
index 3e39231..70ac8bf 100644
--- a/meta/recipes-devtools/python/python-smartpm_1.4.1.bb
+++ b/meta/recipes-devtools/python/python-smartpm_1.4.1.bb
@@ -27,6 +27,7 @@ SRC_URI = "\
file://smart-yaml-error.patch \
file://smart-channelsdir.patch \
file://smart-conflict-provider.patch \
+ file://smart-flag-ignore-recommends.patch \
"
SRC_URI[md5sum] = "573ef32ba177a6b3c4bf7ef04873fcb6"
--
1.8.1.2
More information about the Openembedded-core
mailing list