Home

Awesome

:lipstick: atom-beautify

apm GitHub stars GitHub issues Greenkeeper badge

Slack Twitter Follow Gitter Bountysource Paypal Donations

<!-- **Sign up for Unibeautify CI: [https://goo.gl/jmM4QN](https://goo.gl/jmM4QN)** -->

:point_right: Sign up for CodePass, the Quickest Way To Solve Your Coding Errors! :boom:

:tada: Install Unibeautify CI for GitHub :tada:

Help improve Atom-Beautify by completing the quick questionnaire: https://goo.gl/iEHBNr

Mac OS <img src="https://cloud.githubusercontent.com/assets/1885333/17059766/2530c9d8-4ffd-11e6-9529-3fa47dbff616.png" width="50px"> and <img src="https://cloud.githubusercontent.com/assets/1885333/17059750/11c4474e-4ffd-11e6-89e1-2486ca5b3234.png" width="100px"><img src="https://cloud.githubusercontent.com/assets/1885333/17059763/206a7d4a-4ffd-11e6-859e-7856902fb300.png" width="100px">
Travis CI: Build StatusAppVeyor: Build status

Throughput Graph

Beautify HTML, CSS, JavaScript, PHP, Python, Ruby, Java, C, C++, C#, Objective-C, CoffeeScript, TypeScript, Coldfusion, SQL, and more in Atom

BeforeAfter
Original HTMLBeautified HTML
imageimage

Table of Contents

Installation

Atom Package: https://atom.io/packages/atom-beautify

apm install atom-beautify

Or Settings/Preferences ➔ Install ➔ Search for atom-beautify

:tada: Install Unibeautify CI for GitHub :tada:

Important Notice: Analytics

Atom-Beautify respects the core.telemetryConsent configuration option from Atom editor. If you do not wish to have usage data sent to Google Analytics then please set core.telemetryConsent to no or undecided option before using Atom-Beautify. See Anonymous Analytics section of docs for details. Thank you.

On Atom LoadChange Setting Later
imageimage

Next Version: Unibeautify

Atom-Beautify is going to be completely rewritten with Unibeautify at its core! See unibeautify branch for work in progress and Issue #1174.

:tada: Install Unibeautify CI for GitHub :tada:

Poll: Improving installation of third-party beautifiers

Many users are experiencing issues when installing third party beautifiers (e.g. Uncrustify, PHP-CS-Fixer, and many more). A possible solution is a "cloud" service which provides remote access to these beautifiers. Atom-Beautify would then communicate with these services, allowing for zero-installation beautification.

Please let us know what you think!

Beautifiers

Some of the supported beautifiers are developed for Node.js and are automatically installed when Atom-Beautify is installed. However, other beautifiers are command-line interface (CLI) applications and require you to manually install them.

BeautifierPreinstalled:whale: DockerInstallation
align-yaml:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
autopep8:warning: 2 executables:warning: Only 1 of 2 executables:whale: With Docker:<br/>1. Install autopep8 (autopep8) with docker pull unibeautify/autopep8<br/><br/>:bookmark_tabs: Manually:<br/>1. Install autopep8 (autopep8) by following https://github.com/hhatto/autopep8#installation<br/>2. Install isort (isort) by following https://github.com/timothycrosley/isort#installing-isort<br/>
beautysh:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install beautysh (beautysh) with docker pull unibeautify/beautysh<br/><br/>:bookmark_tabs: Manually:<br/>1. Install beautysh (beautysh) by following https://github.com/bemeurer/beautysh#installation<br/>
black:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install black (black) by following https://github.com/ambv/black#installation<br/>
brittany:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/lspitzner/brittany and follow the instructions.
clang-format:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install ClangFormat (clang-format) with docker pull unibeautify/clang-format<br/><br/>:bookmark_tabs: Manually:<br/>1. Install ClangFormat (clang-format) by following https://clang.llvm.org/docs/ClangFormat.html<br/>
cljfmt:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Coffee Formatter:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
coffee-fmt:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Crystal:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install Crystal (crystal) with docker pull unibeautify/crystal<br/><br/>:bookmark_tabs: Manually:<br/>1. Install Crystal (crystal) by following https://crystal-lang.org/docs/installation/<br/>
CSScomb:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
dfmt:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install Dfmt (dfmt) by following https://github.com/dlang-community/dfmt#building<br/>
elm-format:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install elm-format (elm-format) with docker pull unibeautify/elm-format<br/><br/>:bookmark_tabs: Manually:<br/>1. Install elm-format (elm-format) by following https://github.com/avh4/elm-format#installation-<br/>
Emacs Verilog Mode:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install Emacs (emacs) by following https://www.gnu.org/software/emacs/<br/>
erl_tidy:warning: Manual installation:construction: Not an executable:page_facing_up: Go to http://erlang.org/doc/man/erl_tidy.html and follow the instructions.
ESLint Fixer:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
formatR:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install Rscript (rscript) with docker pull unibeautify/rscript<br/><br/>:bookmark_tabs: Manually:<br/>1. Install Rscript (rscript) by following https://github.com/yihui/formatR<br/>
Fortran Beautifier:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install Emacs (emacs) by following https://www.gnu.org/software/emacs/<br/>
Gherkin formatter:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
GN:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install gn (gn) by following https://www.chromium.org/developers/how-tos/get-the-code<br/>
gofmt:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://golang.org/cmd/gofmt/ and follow the instructions.
goimports:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install goimports (goimports) with docker pull unibeautify/goimports<br/><br/>:bookmark_tabs: Manually:<br/>1. Install goimports (goimports) by following https://godoc.org/golang.org/x/tools/cmd/goimports<br/>
hh_format:warning: Manual installation:construction: Not an executable:page_facing_up: Go to http://hhvm.com/ and follow the instructions.
hindent:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/commercialhaskell/hindent and follow the instructions.
HTML Beautifier:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/threedaymonk/htmlbeautifier and follow the instructions.
JS Beautify:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
JSCS Fixer:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Latex Beautify:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/cmhughes/latexindent.pl and follow the instructions.
Lua beautifier:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Marko Beautifier:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Nginx Beautify:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
ocamlformat:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install ocamlformat (ocamlformat) by following https://github.com/ocaml-ppx/ocamlformat#installation<br/>
ocp-indent:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install ocp-indent (ocp-indent) with docker pull unibeautify/ocp-indent<br/><br/>:bookmark_tabs: Manually:<br/>1. Install ocp-indent (ocp-indent) by following https://www.typerex.org/ocp-indent.html#installation<br/>
Perltidy:warning: Manual installation:construction: Not an executable:page_facing_up: Go to http://perltidy.sourceforge.net/ and follow the instructions.
PHP-CS-Fixer:warning: 2 executables:warning: Only 1 of 2 executables:whale: With Docker:<br/>1. Install PHP-CS-Fixer (php-cs-fixer) with docker pull unibeautify/php-cs-fixer<br/><br/>:bookmark_tabs: Manually:<br/>1. Install PHP (php) by following http://php.net/manual/en/install.php<br/>2. Install PHP-CS-Fixer (php-cs-fixer) by following https://github.com/FriendsOfPHP/PHP-CS-Fixer#installation<br/>
PHPCBF:warning: 2 executables:warning: Only 1 of 2 executables:whale: With Docker:<br/>1. Install PHPCBF (phpcbf) with docker pull unibeautify/phpcbf<br/><br/>:bookmark_tabs: Manually:<br/>1. Install PHP (php) by following http://php.net/manual/en/install.php<br/>2. Install PHPCBF (phpcbf) by following https://github.com/squizlabs/PHP_CodeSniffer#installation<br/>
Prettier:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Pretty Diff:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Pug Beautify:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
puppet-lint:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install puppet-lint (puppet-lint) with docker pull unibeautify/puppet-lint<br/><br/>:bookmark_tabs: Manually:<br/>1. Install puppet-lint (puppet-lint) by following http://puppet-lint.com/<br/>
pybeautifier:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/guyskk/pybeautifier and follow the instructions.
Remark:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Rubocop:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install Rubocop (rubocop) by following http://rubocop.readthedocs.io/en/latest/installation/<br/>
Ruby Beautify:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/erniebrodeur/ruby-beautify and follow the instructions.
rustfmt:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/rust-lang-nursery/rustfmt and follow the instructions.
SassConvert:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install SassConvert (sass-convert) with docker pull unibeautify/sass-convert<br/><br/>:bookmark_tabs: Manually:<br/>1. Install SassConvert (sass-convert) by following http://sass-lang.com/documentation/file.SASS_REFERENCE.html#syntax<br/>
sqlformat:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/andialbrecht/sqlparse and follow the instructions.
stylish-haskell:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/jaspervdj/stylish-haskell and follow the instructions.
terraformfmt:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install Terraform (terraform) with docker pull hashicorp/terraform<br/><br/>:bookmark_tabs: Manually:<br/>1. Install Terraform (terraform) by following https://www.terraform.io<br/>
Tidy Markdown:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
TypeScript Formatter:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
Uncrustify:warning: 1 executable:white_check_mark: :100:% of executables:whale: With Docker:<br/>1. Install Uncrustify (uncrustify) with docker pull unibeautify/uncrustify<br/><br/>:bookmark_tabs: Manually:<br/>1. Install Uncrustify (uncrustify) by following https://github.com/uncrustify/uncrustify<br/>
VHDL Beautifier:warning: 1 executable:x: No Docker support:bookmark_tabs: Manually:<br/>1. Install Emacs (emacs) by following https://www.gnu.org/software/emacs/<br/>
Vue Beautifier:white_check_mark::ok_hand: Not necessary:smiley: Nothing!
yapf:warning: Manual installation:construction: Not an executable:page_facing_up: Go to https://github.com/google/yapf and follow the instructions.

Language Support

See all supported options in the documentation at docs/options.md.

LanguageGrammarsFile ExtensionsSupported Beautifiers
ApexApex.cls, .triggerUncrustify
ArduinoArduino.ino, .pdeUncrustify
BashShell Script.bash, .shbeautysh
BladeBlade.blade.phpJS Beautify
CC, opencl.h, .c, .clUncrustify, clang-format
Coldfusionhtml.cfm, .cfml, .cfcPretty Diff
ClojureClojure.clj, .cljs, .edncljfmt
CoffeeScriptCoffeeScript.coffeecoffee-fmt, Coffee Formatter
C++C++.h, .hh, .cc, .cpp, .cxx, .C, .cu, .c++, .hpp, .hxx, .h++, .cuhUncrustify, clang-format
CrystalCrystal.crCrystal
C#C#.csUncrustify
CSSCSS.cssJS Beautify, CSScomb, Prettier, Pretty Diff, SassConvert
CSVCSV.csvPretty Diff
DD.dUncrustify, dfmt
EJSEJS, JavaScript Template, HTML (Angular).ejsJS Beautify, Pretty Diff
ElmElm.elmelm-format
ERBHTML (Ruby - ERB), HTML (Rails).erbPretty Diff, HTML Beautifier
ErlangErlang.erlerl_tidy
FortranFortran - Modern.f90, .F90, .f95, .F95, .f03, .F03, .f08, .F08Fortran Beautifier
gherkinGherkin.featureGherkin formatter
GLSLC, opencl, GLSL.vert, .fragclang-format
GNgn.gn, .gniGN
GoGo.gogofmt, goimports
Golang TemplateHTML (Go), Go Template.gohtmlPretty Diff
HandlebarsHandlebars, HTML (Handlebars).hbs, .handlebarsJS Beautify, Pretty Diff
HaskellHaskell.hsstylish-haskell, brittany, hindent
HTMLHTML.htmlJS Beautify, Pretty Diff
JadeJade, Pug.jade, .pugPug Beautify
JavaJava.javaUncrustify
JavaScriptJavaScript.jsJS Beautify, ESLint Fixer, JSCS Fixer, Prettier, Pretty Diff
JSONJSON.jsonJS Beautify, Prettier, Pretty Diff
JSXJSX, JavaScript (JSX), Babel ES6 JavaScript, JavaScript with JSX.jsx, .jsPretty Diff, JS Beautify
LaTeXBibTeX, LaTeX, TeX.bib, .tex, .sty, .cls, .dtx, .ins, .bbx, .cbxLatex Beautify
LESSLESS.lessPretty Diff, CSScomb, Prettier
LuaLua.lua, .ttsluaLua beautifier
MarkdownGitHub Markdown.markdown, .mdRemark, Prettier, Tidy Markdown
MarkoMarko.markoMarko Beautifier
MustacheHTML (Mustache).mustacheJS Beautify, Pretty Diff
Nginxnginx.confNginx Beautify
NunjucksNunjucks, Nunjucks Templates, HTML (Nunjucks Templates).njk, .nunjucksPretty Diff
Objective-CObjective-C, Objective-C++.m, .mm, .hUncrustify, clang-format
OCamlOCaml.mlocp-indent, ocamlformat
PawnPawnUncrustify
PerlPerl, Perl 6.pl, .PL, .pm, .pod, .tPerltidy
PHPPHP.php, .module, .incPHP-CS-Fixer, PHPCBF, hh_format
PuppetPuppet.pppuppet-lint
PythonPython, MagicPython.pyautopep8, black, pybeautifier, yapf
RR.r, .RformatR
Riot.jsRiot.js, HTML (Riot Tag).tagPretty Diff
RubyRuby, Ruby on Rails.rbRubocop, Ruby Beautify
RustRust.rs, .rlibrustfmt
SassSass.sassSassConvert
SCSSSCSS.scssPretty Diff, CSScomb, Prettier, SassConvert
SpacebarsSpacebarsPretty Diff
SQLSQL (Rails), SQL.sqlsqlformat
SVGSVG.svgPretty Diff
SwigHTML (Swig), SWIG.swigPretty Diff
TerraformTerraform.tfterraformfmt
TSSTSS.tssPretty Diff
TSXTypeScriptReact.tsxTypeScript Formatter
TwigHTML (Twig).twigPretty Diff
TypeScriptTypeScript.tsTypeScript Formatter, Prettier
UX MarkupUX.uxPretty Diff
ValaVala.vala, .vapiUncrustify
VerilogVerilog.svh, .v, .svEmacs Verilog Mode
VHDLVHDL 2008.vhd, .VHDVHDL Beautifier
VisualforceVisualforce.pagePretty Diff
VueVue Component.vueVue Beautifier, ESLint Fixer, Prettier
XMLSLD, XML, XHTML, XSD, XSL, JSP, GSP.sld, .xml, .xhtml, .xsd, .xsl, .jsp, .gsp, .plist, .recipe, .configPretty Diff, JS Beautify
XTemplateXTemplate.xtemplatePretty Diff
YAMLYAML.yml, .yamlalign-yaml

Usage

Command Palette

Open the Command Palette, type Beautify, and run Beautify Editor.

image

Beautify a Specific Language

You can use the Command Palette to beautify the editor for a specific language. The commands are in the form Atom Beautify: Beautify Language {NAME} (i.e. atom-beautify:beautify-language-{NAME} for keyboard shortcuts). For example, you may want to beautify JavaScript code within a HTML file.

atom-beautify-language-commands

Selection of Code

It will only beautify selected text if a selection is found -- if not, the whole file will be beautified.

Selection of CodeBeautify Selection of CodeBeautify Entire File
Select code in Atom editorOnly that selection is beautifiedWithout a selection all code is beautified
imageimageimage

Beautify On Save

Beautify On Save can be enabled for each language individually.

For example, for language HTML go into Atom-Beautify's package settings (AtomPreferences ➔ Search for atom-beautify), find HTML, and toggle the Beautify On Save option.

atom-beautify-setup-beautify-on-save

Keyboard Shortcut

You can also type <kbd>Ctrl</kbd>-<kbd>Alt</kbd>-<kbd>B</kbd> as a shortcut or click Packages > Beautify in the menu.

Custom Keyboard Shortcuts

See Keymaps In-Depth for more details.

For example:

'.editor':
  'ctrl-alt-b': 'atom-beautify:beautify-editor'

Configuration

Edit your .jsbeautifyrc file in any of the following locations:

Note: Comments are supported in .jsbeautifyrc thanks to strip-json-comments.

See examples of both ways inside examples/

See all supported options in the documentation at docs/options.md.

Simple

See examples/simple-jsbeautifyrc/.jsbeautifyrc.

{
  "indent_size": 2,
  "indent_char": " ",
  "other": " ",
  "indent_level": 0,
  "indent_with_tabs": false,
  "preserve_newlines": true,
  "max_preserve_newlines": 2,
  "jslint_happy": true,
  "indent_handlebars": true
}

Nested (Recommended)

See examples/nested-jsbeautifyrc/.jsbeautifyrc.

{
  "html": {
    "brace_style": "collapse",
    "indent_char": " ",
    "indent_scripts": "normal",
    "indent_size": 6,
    "max_preserve_newlines": 1,
    "preserve_newlines": true,
    "unformatted": ["a", "sub", "sup", "b", "i", "u"],
    "wrap_line_length": 0
  },
  "css": {
    "indent_char": " ",
    "indent_size": 4
  },
  "js": {
    "indent_size": 2,
    "indent_char": " ",
    "indent_level": 0,
    "indent_with_tabs": false,
    "preserve_newlines": true,
    "max_preserve_newlines": 2,
    "jslint_happy": true
  },
  "sql": {
    "indent_size": 4,
    "indent_char": " ",
    "indent_level": 0,
    "indent_with_tabs": false
  }
}

Troubleshooting

See docs/troubleshooting.md.

Contributing

See CONTRIBUTING.md.

See all contributors on GitHub.

Please update the CHANGELOG.md, add yourself as a contributor to the package.json, and submit a Pull Request on GitHub.

License

MIT © Glavin Wiechert