-
Notifications
You must be signed in to change notification settings - Fork 257
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
simplify extra markers 2 #845
simplify extra markers 2 #845
Conversation
Without this change the union of `extra == "a" and extra == "c"` and `extra == "a" or extra == "b"` is `extra == "a" and extra == "c" or extra == "a" or extra == "b"`. With the change, it is simplified to `extra == "a" or extra == "b"`.
Reviewer's Guide by SourceryThis pull request simplifies the union of marker constraints, specifically addressing cases where combining an 'or' condition with an 'and' condition can be reduced to a simpler 'or' condition. This optimization avoids unnecessarily complex marker expressions. Sequence diagram for union constraint simplificationsequenceDiagram
participant UC as UnionConstraint
participant MC as MultiConstraint
UC->UC: union(other: MultiConstraint)
alt any(c in other.constraints for c in self._constraints)
UC-->UC: return self
else
UC->UC: new_constraints = [*self._constraints, other]
UC-->UC: return new UnionConstraint(new_constraints)
end
File-Level Changes
Tips and commandsInteracting with Sourcery
Customizing Your ExperienceAccess your dashboard to:
Getting Help
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey @radoering - I've reviewed your changes - here's some feedback:
Overall Comments:
- It might be helpful to add a comment explaining the logic behind the early return in
union
.
Here's what I looked at during the review
- 🟢 General issues: all looks good
- 🟢 Security: all looks good
- 🟢 Testing: all looks good
- 🟢 Complexity: all looks good
- 🟢 Documentation: all looks good
Help me be more useful! Please click 👍 or 👎 on each comment and I'll use the feedback to improve your reviews.
Without this change the union of
extra == "a" and extra == "c"
andextra == "a" or extra == "b"
isextra == "a" and extra == "c" or extra == "a" or extra == "b"
. With the change, it is simplified toextra == "a" or extra == "b"
.Related to: python-poetry/poetry#10195
Similar to: #842
Summary by Sourcery
Tests: