Styler is an Elixir formatter plugin that goes beyond formatting by rewriting your code for consistency, readability, and optimization.
Styler's full feature documentation can be found on Hexdocs.
Styler fixes a plethora of Elixir style and optimization issues automatically as part of mix format.
The fastest way to see what all it can do you for you is to just try it out in your codebase... but here's a list of a few features to help you decide if you're interested in Styler:
- sorts and organizes import,alias,requireand other module directives
- automatically creates aliases for repeatedly referenced modules names ("alias lifting") and makes sure aliases you've defined are being used
- keeps lists, sigils, and even arbitrary code sorted with the # styler:sortcomment directive
- optimizes pipe chains for readability and performance
- rewrites deprecated Elixir standard library code, speeding adoption of new releases
- auto-fixes many credo rules, meaning you can spend less time fighting with CI
I'm just excited to be on a team that uses Styler and moves on
Styler was designed for a large team working in a single codebase (140+ contributors). It helps remove fiddly code review comments and linter CI slowdowns, helping our team get things done faster. Teams in similar situations might appreciate Styler.
Styler has also been extremely valuable for taming legacy Elixir codebases and general refactoring. Some of its rewrites have inspired code actions in Elixir language servers.
Conversely, Styler probably isn't a good match for:
- experimental, macro-heavy codebases
- teams that don't care about code standards
Add :styler as a dependency to your project's mix.exs:
def deps do
  [
    {:styler, "~> 1.9", only: [:dev, :test], runtime: false},
  ]
endThen add Styler as a plugin to your .formatter.exs file
[
  plugins: [Styler]
]And that's it! Now when you run mix format you'll also get the benefits of Styler's Stylish Stylings.
Speed: Expect the first run to take some time as Styler rewrites violations of styles and bottlenecks on disk I/O. Subsequent formats won't take noticeably more time.
Styler can be configured in your .formatter.exs file
[
  plugins: [Styler],
  styler: [
    alias_lifting_exclude: [...],
    minimum_supported_elixir_version: "..."
  ]
]- alias_lifting_exclude: a list of module names to not lift. See the Module Directive documentation for more.
- minimum_supported_elixir_version: intended for library authors; overrides the Elixir version Styler relies on with respect to some deprecation rewrites. See Deprecations documentation for more.
Styler will not add configuration for ad-hoc enabling/disabling of rewrites. Sorry!
However, Smartrent has a fork of Styler named Quokka that allows for finegrained control of Styler. Maybe it's what you're looking for. If not, you can always fork it or Styler as a starting point for your own tool!
Ultimately Styler is @adobe's internal tool that we're happy to share with the world. We're delighted if you like it as is, and just as excited if it's a starting point for you to make something even better for yourself.
While Styler endeavors to never purposefully create bugs, some of its rewrites can introduce them in obscure cases.
It goes without saying, but look over any changes Styler writes before committing to main.
A simple example of a way Styler rewrite can introduce a bug is the following case statement:
# Before: this case statement...
case foo do
  true -> :ok
  false -> :error
end
# After: ... is rewritten by Styler to be an if statement!.
if foo do
  :ok
else
  :error
endThese programs are not semantically equivalent. The former would raise if foo returned any value other than true or false, while the latter blissfully completes.
If issues like this bother you, Styler probably isn't the tool you're looking for.
Other ways Styler could introduce runtime bugs:
- withstatement rewrites
- config file sorting
- and likely other ways. stay safe out there!
Styler's first incarnation was as one-off scripts to rewrite an internal codebase to allow Credo rules to be turned on.
These rewrites were entirely powered by the terrific Sourceror library.
While Styler no longer relies on Sourceror, we're grateful for its author's help with those scripts, the inspiration
Sourceror provided in showing us what was possible, and the changes to the Elixir AST APIs that it drove.
Styler's AST-Zipper implementation in this project was forked from Sourceror. Zipper has been a crucial part of our ability to ergonomically zip around (heh) Elixir AST.
We never would've bothered trying to rewrite our codebase if we didn't have Credo rules we wanted to apply.
Credo's tests and implementations were referenced for implementing Styles that took the work the rest of the way.
Thanks to Credo & the Elixir community at large for coalescing around many of these Elixir style credos.