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

trigger obfuscated_if_else for .then(..).unwrap_or(..) #14021

Merged
merged 1 commit into from
Jan 25, 2025

Conversation

lapla-cogito
Copy link
Contributor

@lapla-cogito lapla-cogito commented Jan 18, 2025

part of #9100

The obfuscated_if_else lint currently only triggers for the pattern .then_some(..).unwrap_or(..), but there're other cases where this lint should be triggered, one of which is .then(..).unwrap_or(..).

changelog: [obfuscated_if_else]: trigger lint for the .then(..).unwrap_or(..) pattern as well

@rustbot
Copy link
Collaborator

rustbot commented Jan 18, 2025

r? @llogiq

rustbot has assigned @llogiq.
They will have a look at your PR within the next two weeks and either review your PR or reassign to another reviewer.

Use r? to explicitly pick a reviewer

@rustbot rustbot added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties label Jan 18, 2025
@lapla-cogito lapla-cogito force-pushed the obfusifelse_then_unwrapor branch from 0fb2747 to 4eb060d Compare January 18, 2025 10:14
@lapla-cogito lapla-cogito force-pushed the obfusifelse_then_unwrapor branch 3 times, most recently from 52e688c to ef52d42 Compare January 18, 2025 12:27
@lapla-cogito
Copy link
Contributor Author

lapla-cogito commented Jan 18, 2025

Also I'm willing to implement for other patterns that should be covered by obfuscated_if_else. (But in other PRs)

@lapla-cogito lapla-cogito force-pushed the obfusifelse_then_unwrapor branch from ef52d42 to 190af4c Compare January 19, 2025 12:23
@samueltardieu
Copy link
Contributor

samueltardieu commented Jan 19, 2025

Also I'm willing to implement for other patterns that should be covered by obfuscated_if_else. (But in other PRs)

May I ask why you don't want to do it in this PR? As far as I can tell, those patterns are all pretty similar and can be split into three categories:

  • either a subpattern takes a value (.then_some(), .unwrap_or()), and they must be checked for side effects before the expression can be transformed into the if
  • or they take a lambda expression (.then(), .unwrap_or_else()), which is not evaluated if the condition doesn't match so this is already compatible with the if syntax you are proposing
  • or it is .unwrap_or_default() which doesn't take anything and may be replaced with a else { Default::default() }

Or are there some subtleties I am missing there?

@lapla-cogito
Copy link
Contributor Author

lapla-cogito commented Jan 19, 2025

May I ask why you don't want to do it in this PR?

Aren't there quite a lot of patterns that should really be handled by obfuscated_if_else? That is, I think this lint should finally support the following method combinations:
[then, then_some] x [unwrap_or, map_or, unwrap_or_default, map_or_else, is_some_and]
Since it's already implemented for the then_some and unwrap_or combinations, we need to address the rest of the patterns, but I thought it would be excessive to make changes to all of them in this single PR.

@samueltardieu
Copy link
Contributor

samueltardieu commented Jan 19, 2025

Aren't there quite a lot of patterns that should really be handled by obfuscated_if_else?

In my opinion, this lint is for something which doesn't return an Option, as in this case the if form might not be the best one (or it would have to move to restriction).

For example, some of the combinations listed, such as some_bool.then_some(v).map_or(|x| f(x, 3)), would probably be best handled by a lint which transforms it into some_bool.then(|| f(v, 3)) (which might in turn trigger the present lint after the fix if it is followed by an .unwrap_or() for example). (you are right about .map_or())

Since it's already implemented for the then_some and unwrap_or combinations

I'll open an issue btw since this gave us a chance to notice that it doesn't detect side effects (not caused by your PR of course).

@lapla-cogito
Copy link
Contributor Author

lapla-cogito commented Jan 20, 2025

The problems with the previous implementation of obfuscated_if_else should be fixed here, so I think this patch is ready for review on its own. @llogiq

Copy link
Contributor

@llogiq llogiq left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Only a few small nits, otherwise this looks good to me.

clippy_lints/src/methods/obfuscated_if_else.rs Outdated Show resolved Hide resolved
tests/ui/obfuscated_if_else.rs Show resolved Hide resolved
clippy_lints/src/methods/obfuscated_if_else.rs Outdated Show resolved Hide resolved
@lapla-cogito lapla-cogito force-pushed the obfusifelse_then_unwrapor branch from 190af4c to f42093c Compare January 25, 2025 10:54
@lapla-cogito lapla-cogito force-pushed the obfusifelse_then_unwrapor branch from f42093c to db97768 Compare January 25, 2025 10:57
@lapla-cogito lapla-cogito requested a review from llogiq January 25, 2025 11:03
@llogiq
Copy link
Contributor

llogiq commented Jan 25, 2025

Thank you!

@llogiq llogiq added this pull request to the merge queue Jan 25, 2025
Merged via the queue into rust-lang:master with commit 9135923 Jan 25, 2025
11 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-waiting-on-review Status: Awaiting review from the assignee but also interested parties
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants