|
|
92f559 |
From eb1d6edf55c167d575ce3d16bd6349e382d05600 Mon Sep 17 00:00:00 2001
|
|
|
92f559 |
From: Masahiro Matsuya <mmatsuya@redhat.com>
|
|
|
92f559 |
Date: Wed, 13 Apr 2022 18:42:03 +0900
|
|
|
92f559 |
Subject: [PATCH] feat(repomanage): Add new option --oldonly
|
|
|
92f559 |
|
|
|
92f559 |
= changelog =
|
|
|
92f559 |
msg: repomanage: Add new option --oldonly
|
|
|
92f559 |
type: enhancement
|
|
|
92f559 |
resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2034736
|
|
|
92f559 |
resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2058676
|
|
|
92f559 |
---
|
|
|
92f559 |
doc/repomanage.rst | 3 +++
|
|
|
92f559 |
plugins/repomanage.py | 46 ++++++++++++++++++++++++++++++++++++++++---
|
|
|
92f559 |
2 files changed, 46 insertions(+), 3 deletions(-)
|
|
|
92f559 |
|
|
|
92f559 |
diff --git a/doc/repomanage.rst b/doc/repomanage.rst
|
|
|
92f559 |
index e3171ef..3c01289 100644
|
|
|
92f559 |
--- a/doc/repomanage.rst
|
|
|
92f559 |
+++ b/doc/repomanage.rst
|
|
|
92f559 |
@@ -47,6 +47,9 @@ The following options set what packages are displayed. These options are mutuall
|
|
|
92f559 |
``--old``
|
|
|
92f559 |
Show older packages (for a package or a stream show all versions except the newest one).
|
|
|
92f559 |
|
|
|
92f559 |
+``--oldonly``
|
|
|
92f559 |
+ Show older packages (same as --old, but exclude the newest packages even when it's included in the older stream versions).
|
|
|
92f559 |
+
|
|
|
92f559 |
``--new``
|
|
|
92f559 |
Show newest packages.
|
|
|
92f559 |
|
|
|
92f559 |
diff --git a/plugins/repomanage.py b/plugins/repomanage.py
|
|
|
92f559 |
index 67a6fc7..d23497a 100644
|
|
|
92f559 |
--- a/plugins/repomanage.py
|
|
|
92f559 |
+++ b/plugins/repomanage.py
|
|
|
92f559 |
@@ -57,6 +57,12 @@ class RepoManageCommand(dnf.cli.Command):
|
|
|
92f559 |
def run(self):
|
|
|
92f559 |
if self.opts.new and self.opts.old:
|
|
|
92f559 |
raise dnf.exceptions.Error(_("Pass either --old or --new, not both!"))
|
|
|
92f559 |
+ if self.opts.new and self.opts.oldonly:
|
|
|
92f559 |
+ raise dnf.exceptions.Error(_("Pass either --oldonly or --new, not both!"))
|
|
|
92f559 |
+ if self.opts.old and self.opts.oldonly:
|
|
|
92f559 |
+ raise dnf.exceptions.Error(_("Pass either --old or --oldonly, not both!"))
|
|
|
92f559 |
+ if not self.opts.old and not self.opts.oldonly:
|
|
|
92f559 |
+ self.opts.new = True
|
|
|
92f559 |
|
|
|
92f559 |
verfile = {}
|
|
|
92f559 |
pkgdict = {}
|
|
|
92f559 |
@@ -123,8 +129,7 @@ class RepoManageCommand(dnf.cli.Command):
|
|
|
92f559 |
# modular packages
|
|
|
92f559 |
keepnum_latest_stream_artifacts = set()
|
|
|
92f559 |
|
|
|
92f559 |
- # if new
|
|
|
92f559 |
- if not self.opts.old:
|
|
|
92f559 |
+ if self.opts.new:
|
|
|
92f559 |
# regular packages
|
|
|
92f559 |
for (n, a) in pkgdict.keys():
|
|
|
92f559 |
evrlist = pkgdict[(n, a)]
|
|
|
92f559 |
@@ -146,7 +151,6 @@ class RepoManageCommand(dnf.cli.Command):
|
|
|
92f559 |
for stream in streams_by_version[i]:
|
|
|
92f559 |
keepnum_latest_stream_artifacts.update(set(stream.getArtifacts()))
|
|
|
92f559 |
|
|
|
92f559 |
-
|
|
|
92f559 |
if self.opts.old:
|
|
|
92f559 |
# regular packages
|
|
|
92f559 |
for (n, a) in pkgdict.keys():
|
|
|
92f559 |
@@ -169,6 +173,40 @@ class RepoManageCommand(dnf.cli.Command):
|
|
|
92f559 |
for stream in streams_by_version[i]:
|
|
|
92f559 |
keepnum_latest_stream_artifacts.update(set(stream.getArtifacts()))
|
|
|
92f559 |
|
|
|
92f559 |
+ if self.opts.oldonly:
|
|
|
92f559 |
+ # regular packages
|
|
|
92f559 |
+ for (n, a) in pkgdict.keys():
|
|
|
92f559 |
+ evrlist = pkgdict[(n, a)]
|
|
|
92f559 |
+
|
|
|
92f559 |
+ oldevrs = evrlist[:-keepnum]
|
|
|
92f559 |
+
|
|
|
92f559 |
+ for package in oldevrs:
|
|
|
92f559 |
+ nevra = self._package_to_nevra(package)
|
|
|
92f559 |
+ for fpkg in verfile[nevra]:
|
|
|
92f559 |
+ outputpackages.append(fpkg)
|
|
|
92f559 |
+
|
|
|
92f559 |
+ # modular packages
|
|
|
92f559 |
+ keepnum_newer_stream_artifacts = set()
|
|
|
92f559 |
+
|
|
|
92f559 |
+ for streams_by_version in module_dict.values():
|
|
|
92f559 |
+ sorted_stream_versions = sorted(streams_by_version.keys())
|
|
|
92f559 |
+
|
|
|
92f559 |
+ new_sorted_stream_versions = sorted_stream_versions[-keepnum:]
|
|
|
92f559 |
+
|
|
|
92f559 |
+ for i in new_sorted_stream_versions:
|
|
|
92f559 |
+ for stream in streams_by_version[i]:
|
|
|
92f559 |
+ keepnum_newer_stream_artifacts.update(set(stream.getArtifacts()))
|
|
|
92f559 |
+
|
|
|
92f559 |
+ for streams_by_version in module_dict.values():
|
|
|
92f559 |
+ sorted_stream_versions = sorted(streams_by_version.keys())
|
|
|
92f559 |
+
|
|
|
92f559 |
+ old_sorted_stream_versions = sorted_stream_versions[:-keepnum]
|
|
|
92f559 |
+
|
|
|
92f559 |
+ for i in old_sorted_stream_versions:
|
|
|
92f559 |
+ for stream in streams_by_version[i]:
|
|
|
92f559 |
+ for artifact in stream.getArtifacts():
|
|
|
92f559 |
+ if artifact not in keepnum_newer_stream_artifacts:
|
|
|
92f559 |
+ keepnum_latest_stream_artifacts.add(artifact)
|
|
|
92f559 |
|
|
|
92f559 |
modular_packages = [self._package_to_path(x) for x in query.filter(pkg__eq=query.filter(nevra_strict=keepnum_latest_stream_artifacts)).available()]
|
|
|
92f559 |
outputpackages = outputpackages + modular_packages
|
|
|
92f559 |
@@ -183,6 +221,8 @@ class RepoManageCommand(dnf.cli.Command):
|
|
|
92f559 |
def set_argparser(parser):
|
|
|
92f559 |
parser.add_argument("-o", "--old", action="store_true",
|
|
|
92f559 |
help=_("Print the older packages"))
|
|
|
92f559 |
+ parser.add_argument("-O", "--oldonly", action="store_true",
|
|
|
92f559 |
+ help=_("Print the older packages. Exclude the newest packages."))
|
|
|
92f559 |
parser.add_argument("-n", "--new", action="store_true",
|
|
|
92f559 |
help=_("Print the newest packages"))
|
|
|
92f559 |
parser.add_argument("-s", "--space", action="store_true",
|
|
|
92f559 |
--
|
|
|
92f559 |
2.36.1
|
|
|
92f559 |
|