View Source Credo.Check.Refactor.FilterReject (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 0 and works with any version of Elixir.

Explanation

One Enum.filter/2 is more efficient than Enum.filter/2 |> Enum.reject/2.

This should be refactored:

["a", "b", "c"]
|> Enum.filter(&String.contains?(&1, "x"))
|> Enum.reject(&String.contains?(&1, "a"))

to look like this:

Enum.filter(["a", "b", "c"], fn letter ->
  String.contains?(letter, "x") && !String.contains?(letter, "a")
end)

The reason for this is performance, because the two calls to Enum.reject/2 and Enum.filter/2 require two iterations whereas doing the functions in the single Enum.filter/2 only requires one.

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.