View Source mix surface.format (Surface v0.12.0)
Formatter Plugin Preferred
To format Surface code using Elixir 1.13 or later, use
Surface.Formatter.Plugin
.
Formats Surface ~F
sigils and .sface
files in the given files and patterns.
$ mix surface.format "lib/**/*.{ex,exs}" "test/**/*.{ex,exs}"
$ cat path/to/file.ex | mix surface.format -
Takes the same options as mix format
except for --check-equivalent
.
Formatting options
Like mix format
, the Surface formatter reads a .formatter.exs
file in the
current directory for formatter configuration. The Surface formatter accepts
the same options as mix format
. Read more about the expected format of
.formatter.exs
and the shared configuration options
documented here.
The Surface formatter also takes the following two additional options
specified in .formatter.exs
:
:surface_line_length
overrides:line_length
only formix surface.format
(:line_length
is used otherwise, or defaults to 98):surface_inputs
overrides:inputs
only formix surface.format
(:inputs
is used otherwise)
Task-specific options
The Surface formatter accepts the same task-specific options as mix format
.
Read documentation for the options documented here..
For quick reference, here are some examples of using these options:
$ mix surface.format --check-formatted
** (Mix) mix surface.format failed due to --check-formatted.
The following files are not formatted:
* path/to/component.ex
* path/to/file.sface
$ mix surface.format --dry-run
$ mix surface.format --dot-formatter path/to/.formatter.exs
You can also use the same syntax as mix format
for specifying which files to
format:
$ mix surface.format path/to/file.ex "lib/**/*.{ex,exs}" "test/**/*.{ex,exs}"