From 14cfc38dac4323f42897dc2e58544ff344541ae2 Mon Sep 17 00:00:00 2001 From: Logan Hunt <39638017+dosisod@users.noreply.github.com> Date: Mon, 2 Oct 2023 23:29:08 -0700 Subject: [PATCH] Update docs for FURB107 (`use-suppress`) (#292): See https://github.com/dosisod/refurb/issues/28#issuecomment-1744147360 --- docs/checks.md | 7 +++++-- refurb/checks/contextlib/with_suppress.py | 7 +++++-- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/docs/checks.md b/docs/checks.md index 76c17ff..44057f5 100644 --- a/docs/checks.md +++ b/docs/checks.md @@ -142,8 +142,8 @@ spaces_4 = "\thello world".expandtabs(4) Categories: `contextlib` `readability` -Often times you want to handle an exception, and just ignore it. You can do -this with a `try/except` block, using a single `pass` in the `except` +Often times you want to handle an exception and just ignore it. You can do +this with a `try`/`except` block with a single `pass` in the `except` block, but there is a simpler and more concise way using the `suppress()` function from `contextlib`: @@ -164,6 +164,9 @@ with suppress(FileNotFoundError): f() ``` +Note: `suppress()` is slower than using `try`/`except`, so for performance +critical code you might consider ignoring this check. + ## FURB108: `use-in-oper` Categories: `logical` `readability` diff --git a/refurb/checks/contextlib/with_suppress.py b/refurb/checks/contextlib/with_suppress.py index ade2e21..e27caf5 100644 --- a/refurb/checks/contextlib/with_suppress.py +++ b/refurb/checks/contextlib/with_suppress.py @@ -8,8 +8,8 @@ @dataclass class ErrorInfo(Error): """ - Often times you want to handle an exception, and just ignore it. You can do - this with a `try/except` block, using a single `pass` in the `except` + Often times you want to handle an exception and just ignore it. You can do + this with a `try`/`except` block with a single `pass` in the `except` block, but there is a simpler and more concise way using the `suppress()` function from `contextlib`: @@ -29,6 +29,9 @@ class ErrorInfo(Error): with suppress(FileNotFoundError): f() ``` + + Note: `suppress()` is slower than using `try`/`except`, so for performance + critical code you might consider ignoring this check. """ name = "use-with-suppress"