All Projects → avh4 → Elm Format

avh4 / Elm Format

Licence: bsd-3-clause
elm-format formats Elm source code according to a standard set of rules based on the official Elm Style Guide

Programming Languages

haskell
3896 projects
elm
856 projects

Projects that are alternatives of or similar to Elm Format

ex format
ExFormat formats Elixir source code according to a standard set of rules
Stars: ✭ 39 (-96.85%)
Mutual labels:  formatter, code-style
Editorconfig Netbeans
A NetBeans IDE plugin supporting the EditorConfig standard. ⛺
Stars: ✭ 123 (-90.08%)
Mutual labels:  code-style, formatter
prettier-check
Check that all files match prettier code style.
Stars: ✭ 54 (-95.65%)
Mutual labels:  formatter, code-style
Uncrustify
Code beautifier
Stars: ✭ 2,442 (+96.94%)
Mutual labels:  code-style, formatter
Laravel Code Style
Automatic code formatting for Laravel projects
Stars: ✭ 344 (-72.26%)
Mutual labels:  code-style, formatter
Swift Style Guide
Swift language style guide & coding conventions followed by Xmartlabs.
Stars: ✭ 36 (-97.1%)
Mutual labels:  code-style
Format Graphql
Formats GraphQL schema definition language (SDL) document.
Stars: ✭ 55 (-95.56%)
Mutual labels:  formatter
Jupyterlab black
A JupyterLab extension to apply Black formatter to code within codecell.
Stars: ✭ 35 (-97.18%)
Mutual labels:  formatter
Eryngii
[WIP] Erlang lint and formatter
Stars: ✭ 28 (-97.74%)
Mutual labels:  formatter
Php Cs Fixer Custom Fixers
A set of custom fixers for PHP CS Fixer
Stars: ✭ 75 (-93.95%)
Mutual labels:  code-style
Typeset
自动修正中文、英文、代码混合排版中的全半角、空格等问题
Stars: ✭ 63 (-94.92%)
Mutual labels:  formatter
Scalafmt
Code formatter for Scala
Stars: ✭ 1,055 (-14.92%)
Mutual labels:  formatter
Google Libphonenumber
The up-to-date and reliable Google's libphonenumber package for node.js.
Stars: ✭ 984 (-20.65%)
Mutual labels:  formatter
Phpstorm Ide Config
My PhpStorm configuration for writing modern PHP code
Stars: ✭ 55 (-95.56%)
Mutual labels:  code-style
Neoformat
✨ A (Neo)vim plugin for formatting code.
Stars: ✭ 977 (-21.21%)
Mutual labels:  formatter
Align
A general purpose application and library for aligning text.
Stars: ✭ 63 (-94.92%)
Mutual labels:  formatter
Scalaunfmt
Generates the .scalafmt.conf that have minimum change to existing your scala codebase on running scalafmt.
Stars: ✭ 35 (-97.18%)
Mutual labels:  formatter
Sqlformat
.NET SQL Parser and Formatter Tool and SSMS Plugin
Stars: ✭ 49 (-96.05%)
Mutual labels:  formatter
Vse Formatdocumentonsave
Visual Studio - Format Document on Save
Stars: ✭ 61 (-95.08%)
Mutual labels:  formatter
Brazilian Utils
Utils library for specific Brazilian businesses
Stars: ✭ 1,023 (-17.5%)
Mutual labels:  formatter

Build Status latest version: 0.8.5

elm-format

elm-format formats Elm source code according to a standard set of rules based on the official Elm Style Guide. It is inspired by the popular gofmt.

The benefits of elm-format:

  • It makes code easier to write, because you never have to worry about minor formatting concerns while powering out new code.
  • It makes code easier to read, because there are no longer distracting minor stylistic differences between different code bases. As such, your brain can map more efficiently from source to mental model.
  • It makes code easier to maintain, because you can no longer have diffs related only to formatting; every diff necessarily involves a material change.
  • It saves your team time debating how to format things, because there is a standard tool that formats everything the same way.
  • It saves you time because you don't have to nitpick over formatting details of your code.

Usage

elm-format .  # Format all *.elm files in the current directory
elm-format Main.elm  # Format a single file
elm-format Main.elm --yes  # Overwrite the file without prompting
elm-format src/ Main.elm  # Format the listed files and directories
elm-format --help  # See other command line options

Installation (latest version: 0.8.5)

To install elm-format:

npm install -g elm-format

or download the version appropriate for your OS from the release page, unzip it, and place elm-format or elm-format.exe (windows) on your PATH.

You must run elm-format from the directory that contains your elm.json (for Elm 0.19) or elm-package.json (for Elm 0.18), or else you must pass the appropriate --elm-version=0.19/--elm-version=0.18 command line argument.

Editor integration

Find your editor in the table below. The recommended plugin for each editor is indicated with 🏆 (trophy emoji).

Editor Plugin Installation Formatting Format on save Configuration Error handling
Atom 🏆 atom-elm-format 2 steps ⚠️ no installation instructions
atom-beautify ⚠️ 3 steps ⚠️ requires configuration
Light Table 🏆 elm-light ⚠️ 3 steps ⚠️ requires configuration ⚠️ no installation instructions
Vim 🏆 elm-vim 6 steps ⚠️ requires configuration ❌ no error message
Emacs 🏆 elm-mode 4 steps ⚠️ requires configuration ⚠️ no installation instructions
Visual Studio Code 🏆 Elm Tooling ⚠️ 3 steps ⚠️ requires configuration ❌ uninformative error message
Sublime Text 🏆 Elm Language Support 2 steps ❔ TBD ❔ TBD ❔ TBD
JetBrains (WebStorm, etc) 🏆 intellij-elm ⚠️ 4 steps ⚠️ requires configuration ⚠️ requires configuration ❔ TBD
TextMate 🏆 Elm.tmbundle 2 steps ❔ TBD ❔ TBD ❔ TBD ❔ TBD

Integration with other tools

These tools also integrate with elm-format:

Detailed installation instructions

If you can simplify or improve the installation instructions or add instructions for another editor, please make a pull request. The default behavior of elm-format-approved plugins is to format Elm files on save.

atom-elm-format installation

  1. Install elm-format

  2. Install atom-elm-format

    apm install elm-format
    

or use the Atom package manager in Atom's settings

atom-beautify installation

  1. Install elm-format

  2. Install atom-beautify

    apm install atom-beautify
    

or use the Atom package manager in Atom's settings

  1. Use ^⌥B (CTRL-ALT-B) to format a file

elm-light installation

  1. Install elm-format
  2. Install the elm-light plugin using the Light Table plugin manager
  3. To format on save, edit your user keymap by performing the following:
  • Click File -> Settings -> User Keymap to open the user keymap.
  • Copy the following line and paste it into your keymap. Anywhere is fine as long as it is whithin the outer brackets. Ensure to save the file.
[:editor.elm "ctrl-s" :save :elm-format :elm.lint]
  • Search for "App: Reload keymaps" in the Commands Window to apply the changes (or restart LightTable).

elm-mode installation

  1. Install elm-format

  2. If your Emacs has package.el (which is automatically the case for Emacs >= 24), you can install elm-mode from the package in MELPA:

    1. Ensure that you have added the MELPA source in your ~/.emacs.d/init.el:

      (require 'package)
      (add-to-list 'package-archives '("melpa" . "http://melpa.org/packages/"))
      
    2. Install elm-mode (official instructions): Use M-x list-packages and choose elm-mode.

  3. Add the following to your ~/.emacs.d/init.el:

    (add-hook 'elm-mode-hook 'elm-format-on-save-mode)
    

elm-vim installation

If you are an advanced vim user and already have a preferred vim plugin installation method, you may prefer to refer to the official elm-vim installation instructions. The instructions below are for those who need a step-by-step walkthrough of how to get the plugin set up.

  1. Install elm-format

  2. Install vim-plug (official instructions) NOTE: if you are using neovim, you will need to refer to the official instructions.

    1. Download vim-plug:

      curl -fLo ~/.vim/autoload/plug.vim --create-dirs \
          https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
      
    2. Make sure ~/.vimrc exists and has a section like this:

      call plug#begin('~/.vim/plugged')
      " ... any active plugins
      call plug#end()
      
  3. Install elm-vim (official instructions)

    1. Add Plug 'elmcast/elm-vim' to the plug#begin plugin section in your ~/.vimrc
    2. Start vim and run :PlugInstall
  4. Add the following to your ~/.vimrc:

let g:elm_format_autosave = 1

Visual Studio Code installation

  1. Install elm-format

  2. Install the extension Elm Plugin for Visual Studio Code.

  3. Configure the extension to format on save:

    1. Find your settings.json file (instructions).
    2. Add the following key-value pair to your settings.json:
    "[elm]": {
        "editor.formatOnSave": true
    },
    

Sublime Text installation

  1. Install elm-format
  2. Install the Elm Language Support package.

JetBrains installation

This is for WebStorm and other JetBrains IDEs like IntelliJ and PyCharm.

  1. Install elm-format

  2. Install the intellij-elm plugin

  3. In IntelliJ, open Settings -> Languages & Frameworks -> Elm

    1. Specify the path to elm-format (try the "Auto Discover" button first)
    2. Check the "Run when file saved?" checkbox

Development info

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

Building from source

  1. Install Haskell ghcup following the instructions for your operating system: https://www.haskell.org/ghcup/
# check out the repo
git clone https://github.com/avh4/elm-format.git
cd elm-format

# initial setup
ghcup install ghc 8.10.4
ghcup set ghc 8.10.4

# build
./build.sh -- build

# run the built elm-format
./_build/elm-format

Running tests

./build.sh
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].