[`flake8-simplify`] Make example error out-of-the-box (`SIM116`) (#19111)

<!--
Thank you for contributing to Ruff/ty! To help us out with reviewing,
please consider the following:

- Does this pull request include a summary of the change? (See below.)
- Does this pull request include a descriptive title? (Please prefix
with `[ty]` for ty pull
  requests.)
- Does this pull request include references to any relevant issues?
-->

## Summary

<!-- What's the purpose of the change? What does it do, and why? -->

Part of #18972

This PR makes [if-else-block-instead-of-dict-lookup
(SIM116)](https://docs.astral.sh/ruff/rules/if-else-block-instead-of-dict-lookup/#if-else-block-instead-of-dict-lookup-sim116)'s
example error out-of-the-box

[Old example](https://play.ruff.rs/718f17ee-fbe2-4520-97c6-153bc0f4502d)
```py
if x == 1:
    return "Hello"
elif x == 2:
    return "Goodbye"
else:
    return "Goodnight"
```

[New example](https://play.ruff.rs/8a9b47b4-da46-4a50-8576-362cdd707cee)
```py
def find_phrase(x):
    if x == 1:
        return "Hello"
    elif x == 2:
        return "Goodbye"
    elif x == 3:
        return "Good morning"
    else:
        return "Goodnight"
```

The "Use instead" section was also updated to reflect the new case. I
also changed it to use an intermediary variable since I find the `return
<long dict>.get` very ugly and hard to read.

## Test Plan

<!-- How was it tested? -->

N/A, no functionality/tests affected
This commit is contained in:
GiGaGon 2025-07-07 14:17:55 -07:00 committed by GitHub
parent de5264fe13
commit 4dd2c03144
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 12 additions and 7 deletions

View File

@ -18,17 +18,22 @@ use crate::checkers::ast::Checker;
/// ///
/// ## Example /// ## Example
/// ```python /// ```python
/// if x == 1: /// def find_phrase(x):
/// return "Hello" /// if x == 1:
/// elif x == 2: /// return "Hello"
/// return "Goodbye" /// elif x == 2:
/// else: /// return "Goodbye"
/// return "Goodnight" /// elif x == 3:
/// return "Good morning"
/// else:
/// return "Goodnight"
/// ``` /// ```
/// ///
/// Use instead: /// Use instead:
/// ```python /// ```python
/// return {1: "Hello", 2: "Goodbye"}.get(x, "Goodnight") /// def find_phrase(x):
/// phrases = {1: "Hello", 2: "Goodye", 3: "Good morning"}
/// return phrases.get(x, "Goodnight")
/// ``` /// ```
#[derive(ViolationMetadata)] #[derive(ViolationMetadata)]
pub(crate) struct IfElseBlockInsteadOfDictLookup; pub(crate) struct IfElseBlockInsteadOfDictLookup;