public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-commits] proj/pkgcore/pkgcheck:master commit in: testdata/data/repos/standalone/DependencyCheck/MissingPackageRevision/, ...
@ 2025-07-11 19:26 Arthur Zamarin
  0 siblings, 0 replies; only message in thread
From: Arthur Zamarin @ 2025-07-11 19:26 UTC (permalink / raw
  To: gentoo-commits

commit:     f850924100957202b8593a3251a874993d858a63
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 11 19:08:11 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Jul 11 19:26:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/pkgcore/pkgcheck.git/commit/?id=f8509241

DependencyCheck: include replacement suggestions

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/pkgcore/pkgcheck/pull/743
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>

 src/pkgcheck/checks/metadata.py                    | 23 +++++++++++++++++++---
 .../MissingPackageRevision/expected.json           | 12 +++++------
 2 files changed, 26 insertions(+), 9 deletions(-)

diff --git a/src/pkgcheck/checks/metadata.py b/src/pkgcheck/checks/metadata.py
index 429c774f..53bfdf2e 100644
--- a/src/pkgcheck/checks/metadata.py
+++ b/src/pkgcheck/checks/metadata.py
@@ -756,15 +756,19 @@ class MissingPackageRevision(results.VersionResult, results.Warning):
     operators.
     """
 
-    def __init__(self, dep, op, atom, **kwargs):
+    def __init__(self, dep: str, op: str, atom: str, suggestions: list[str], **kwargs):
         super().__init__(**kwargs)
         self.dep = dep.upper()
         self.op = op
         self.atom = atom
+        self.suggestions = tuple(suggestions)
 
     @property
     def desc(self):
-        return f'"{self.op}" operator used without package revision: {self.dep}="{self.atom}"'
+        return (
+            f'"{self.op}" operator used without package revision: {self.dep}="{self.atom}"; '
+            f'did you mean either of: {self.suggestions}?'
+        )
 
 
 class MissingUseDepDefault(results.VersionResult, results.Warning):
@@ -910,6 +914,13 @@ class DependencyCheck(Check):
             return missing_use_deps
         return {}
 
+    def _make_replacement_atom(self, orig: atom_cls, op: str, rev: str) -> str:
+        """Make a replacement atom string from orig, with op & rev replaced"""
+        s = f"{op}{orig.key}-{orig.version}{rev}"
+        if orig.blocks:
+            s = ("!!" if orig.blocks_strongly else "!") + s
+        return s
+
     def feed(self, pkg):
         deprecated = defaultdict(set)
 
@@ -960,7 +971,13 @@ class DependencyCheck(Check):
                     # these operators are most likely to mean "the whole version" rather than r0
                     # blockers also matched intentionally
                     if atom.op in ("=", "<=", ">") and not atom.revision:
-                        yield MissingPackageRevision(attr, atom.op, str(atom), pkg=pkg)
+                        repl0 = self._make_replacement_atom(atom, atom.op, "-r0")
+                        if atom.op == "=":
+                            repl1 = self._make_replacement_atom(atom, "~", "")
+                        else:
+                            repl1 = self._make_replacement_atom(atom, atom.op, "-r9999")
+
+                        yield MissingPackageRevision(attr, atom.op, str(atom), [repl0, repl1], pkg=pkg)
 
                     if isinstance(atom, transitive_use_atom) and atom.use is not None:
                         for useflag in atom.use:

diff --git a/testdata/data/repos/standalone/DependencyCheck/MissingPackageRevision/expected.json b/testdata/data/repos/standalone/DependencyCheck/MissingPackageRevision/expected.json
index 96124dea..86ca3797 100644
--- a/testdata/data/repos/standalone/DependencyCheck/MissingPackageRevision/expected.json
+++ b/testdata/data/repos/standalone/DependencyCheck/MissingPackageRevision/expected.json
@@ -1,6 +1,6 @@
-{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "0", "dep": "RDEPEND", "op": "=", "atom": "=stub/stub5-1"}
-{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "1", "dep": "DEPEND", "op": "<=", "atom": "<=stub/stub5-1"}
-{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "2", "dep": "BDEPEND", "op": ">", "atom": ">stub/stub5-0"}
-{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "0-r1", "dep": "RDEPEND", "op": "=", "atom": "!=stub/stub5-0"}
-{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "1-r1", "dep": "RDEPEND", "op": "<=", "atom": "!<=stub/stub5-0"}
-{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "2-r1", "dep": "RDEPEND", "op": ">", "atom": "!>stub/stub5-2"}
+{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "0", "dep": "RDEPEND", "op": "=", "atom": "=stub/stub5-1", "suggestions": ["=stub/stub5-1-r0", "~stub/stub5-1"]}
+{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "0-r1", "dep": "RDEPEND", "op": "=", "atom": "!=stub/stub5-0", "suggestions": ["!=stub/stub5-0-r0", "!~stub/stub5-0"]}
+{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "1", "dep": "DEPEND", "op": "<=", "atom": "<=stub/stub5-1", "suggestions": ["<=stub/stub5-1-r0", "<=stub/stub5-1-r9999"]}
+{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "1-r1", "dep": "RDEPEND", "op": "<=", "atom": "!<=stub/stub5-0", "suggestions": ["!<=stub/stub5-0-r0", "!<=stub/stub5-0-r9999"]}
+{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "2", "dep": "BDEPEND", "op": ">", "atom": ">stub/stub5-0", "suggestions": [">stub/stub5-0-r0", ">stub/stub5-0-r9999"]}
+{"__class__": "MissingPackageRevision", "category": "DependencyCheck", "package": "MissingPackageRevision", "version": "2-r1", "dep": "RDEPEND", "op": ">", "atom": "!>stub/stub5-2", "suggestions": ["!>stub/stub5-2-r0", "!>stub/stub5-2-r9999"]}


^ permalink raw reply related	[flat|nested] only message in thread

only message in thread, other threads:[~2025-07-11 19:26 UTC | newest]

Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-07-11 19:26 [gentoo-commits] proj/pkgcore/pkgcheck:master commit in: testdata/data/repos/standalone/DependencyCheck/MissingPackageRevision/, Arthur Zamarin

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox