Elixir Code Formatter
Guide
Elixir Code Formatter
Paste your Elixir source code and get clean, mix format-style output instantly in your browser. Standardize indentation, normalize spacing around operators, sort alias / import / require / use blocks, and surface syntax problems before they reach iex. Everything runs client-side, so your code never leaves your machine.
How to Use
- Paste Elixir code into the input box, drop a
.ex/.exsfile onto the uploader, or click Try an example. - Optionally adjust the max line length (default 98, matching
mix format) so over-long lines get flagged. - Toggle Sort alias / import / require / use if you want consecutive blocks alphabetized.
- The formatted output appears in real time. Copy it, or download it as
formatted.ex.
Features
- mix format-style indentation – 2-space indent, tracks
do/fn↔endandelse/rescue/catch/afterre-dents. - Operator spacing – standardizes
=,==,|>,->,<-,::,++,<>, and friends. - Map & struct prefixes – tightens
%{...}and%MyStruct{...}without breaking modulo arithmetic. - Bitstring brackets – preserves
<<...>>without adding stray spaces. - Sort alias / import / require / use – alphabetize consecutive blocks (keyword + indent must match).
- Syntax validation – catches unbalanced parens, brackets, braces, bitstrings,
do/endmismatches, and unterminated heredocs. - Line-length warning – flags lines exceeding your configured maximum (40–200).
- Heredocs, sigils, charlists – string interiors and
~r/.../,~s(...),~S"""..."""are preserved verbatim. - Drag-and-drop upload – format any
.ex/.exsfile directly. - 100% client-side – nothing is uploaded; works offline once the page loads.
FAQ
-
What is
mix formatand why does Elixir need one?mix formatis the official Elixir code formatter, introduced in Elixir 1.6. It parses source into an AST and pretty-prints it back using a single, deterministic style. Because every Elixir project shares the same conventions, teams stop arguing about whitespace, code reviews focus on logic instead of layout, and diffs stay clean across editors and operating systems. -
What does the pipe operator
|>actually do?The pipe operator passes the value on its left as the first argument to the function on its right. So
data |> transform() |> save()is equivalent tosave(transform(data)). Pipes read top-to-bottom in the order operations happen, which is why idiomatic Elixir places each|>on its own line indented two spaces from the value being piped. -
Why do Elixir variables look immutable even when they are reassigned?
Elixir variables are rebindings, not mutations.
x = 1followed byx = 2creates a new binding of the namex; the original value1still exists in memory until garbage-collected. Inside pattern matches,=is the match operator, not assignment, which is why{:ok, value} = resultdestructures and binds simultaneously. -
What is the difference between a
doblock and thedo:keyword shorthand?def foo do ... endis the multi-line block form, where the body can contain any number of expressions.def foo, do: expris the keyword-list shorthand for a single-expression body and is parsed as a 2-tuple{:do, expr}in a keyword list. Both produce identical bytecode; the shorthand is preferred for one-liners and the block form for multi-statement bodies. -
Why are charlists and binaries different in Elixir?
A double-quoted string is a UTF-8 binary — a sequence of bytes. A single-quoted charlist is a linked list of Unicode codepoints, inherited from Erlang where strings are traditionally lists of integers. Most Elixir APIs (Phoenix, Ecto, Plug) work with binaries; charlists mainly appear at Erlang interop boundaries (
:inets,:gen_tcp, etc.) where the underlying library expects lists.
Install Our Extensions
Add IO tools to your favorite browser for instant access and faster searching
恵 Scoreboard Has Arrived!
Scoreboard is a fun way to keep track of your games, all data is stored in your browser. More features are coming soon!
Must-Try Tools
View All New Arrivals
View AllUpdate: Our latest tool was added on May 23, 2026
