Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[red-knot] Too many diagnostics for subclasses of cyclic classes #14223

Open
AlexWaygood opened this issue Nov 9, 2024 · 0 comments · May be fixed by #15561
Open

[red-knot] Too many diagnostics for subclasses of cyclic classes #14223

AlexWaygood opened this issue Nov 9, 2024 · 0 comments · May be fixed by #15561
Labels
bug Something isn't working help wanted Contributions especially welcome red-knot Multi-file analysis & type inference

Comments

@AlexWaygood
Copy link
Member

Consider the following Python snippet:

class Foo(Bar): ...
class Bar(Foo): ...
class Baz(Foo): ...
class Spam(Baz): ...

If you save this snippet in a bar.pyi file and run red-knot over that file, red-knot currently emits four diagnostics:

error[cyclic-class-def] /Users/alexw/dev/experiment/bar.pyi:1:1 Cyclic definition of `Foo` or bases of `Foo` (class cannot inherit from itself)
error[cyclic-class-def] /Users/alexw/dev/experiment/bar.pyi:2:1 Cyclic definition of `Bar` or bases of `Bar` (class cannot inherit from itself)
error[cyclic-class-def] /Users/alexw/dev/experiment/bar.pyi:3:1 Cyclic definition of `Baz` or bases of `Baz` (class cannot inherit from itself)
error[cyclic-class-def] /Users/alexw/dev/experiment/bar.pyi:4:1 Cyclic definition of `Spam` or bases of `Spam` (class cannot inherit from itself)

Ideally we'd emit the first two of those diagnostics, but not the third or the fourth. Although it's impossible to calculate an accurate MRO for any of these classes due to the cycle between Foo and Bar, emitting so many diagnostics as a result of a single error is undesirable. If we actually emitted these diagnostics on user code, it would be likely to confuse the user about where the issue actually is.

Baz and Spam are cyclically defined, of course, and we do need to detect that cycle, as we do currently, or we'll try to calculate the MROs of these classes and fall into infinite recursion. I think what we're currently missing is that after detecting the cycle (or perhaps as part of detecting the cycle), we need to do some extra work somewhere to figure out which classes are actually involved in the cycle. Here it is Foo and Bar; we should not emit diagnostics for Baz and Spam, since they are not directly involved in the cycle.

@AlexWaygood AlexWaygood added red-knot Multi-file analysis & type inference help wanted Contributions especially welcome bug Something isn't working labels Nov 9, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working help wanted Contributions especially welcome red-knot Multi-file analysis & type inference
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant