View Source Credo.Check.Refactor.DoubleBooleanNegation (Credo v1.7.11)

Basics

This check is disabled by default.

Learn how to enable it via .credo.exs.

This check is tagged :controversial

This means that this check is more opinionated than others and not for everyone's taste.

This check has a base priority of low and works with any version of Elixir.

Explanation

Having double negations in your code can obscure the parameter's original value.

# NOT preferred

!!var

This will return false for false and nil, and true for anything else.

At first this seems like an extra clever shorthand to cast anything truthy to true and anything non-truthy to false. But in most scenarios you want to be explicit about your input parameters (because it is easier to reason about edge-cases, code-paths and tests). Also: nil and false do mean two different things.

A scenario where you want this kind of flexibility, however, is parsing external data, e.g. a third party JSON-API where a value is sometimes null and sometimes false and you want to normalize that before handing it down in your program.

In these case, you would be better off making the cast explicit by introducing a helper function:

# preferred

defp present?(nil), do: false
defp present?(false), do: false
defp present?(_), do: true

This makes your code more explicit than relying on the implications of !!.

Check-Specific Parameters

There are no specific parameters for this check.

General Parameters

Like with all checks, general params can be applied.

Parameters can be configured via the .credo.exs config file.