You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Adam Stankiewicz d09a56a494 Add unison language support 1 week ago
.github/ISSUE_TEMPLATE Update issue templates 1 year ago
after Update 1 week ago
autoload Update 1 week ago
compiler Add support for ics, closes #492 1 month ago
ctags Update 4 months ago
extras Improve guard so it works for no eof new line 9 months ago
ftdetect Add detection for rspec files (#503) 2 weeks ago
ftplugin Update 1 week ago
indent Update 1 week ago
syntax Add unison language support 1 week ago
.gitignore Add ctags files, fixes #445 4 months ago
.travis.yml Install vim 8 for tests 1 month ago Add unison language support 1 week ago
build Add unison language support 1 week ago
plugin_guard.vim.template Improve guard so it works for no eof new line 9 months ago
plugin_guard_jsx.vim.template Improve guard so it works for no eof new line 9 months ago
test Update travis script 1 month ago


Build Status Maintenance

A collection of language packs for Vim.

One to rule them all, one to find them, one to bring them all and in the darkness bind them.

  • It won’t affect your startup time, as scripts are loaded only on demand*.
  • It installs and updates 120+ times faster than the 152 packages it consists of.
  • Solid syntax and indentation support (other features skipped). Only the best language packs.
  • All unnecessary files are ignored (like enormous documentation from php support).
  • No support for esoteric languages, only most popular ones (modern too, like slim).
  • Each build is tested by automated vimrunner script on CI. See spec directory.

*To be completely honest, optimized ftdetect script takes up to 19ms to load.


  1. Install Pathogen, Vundle, NeoBundle, or Plug package manager for Vim.
  2. Use this repository as submodule or package.

For example when using Plug:

Plug 'sheerun/vim-polyglot'

Optionally download one of the releases and unpack it directly under ~/.vim directory.

You can also use Vim 8 built-in package manager:

mkdir -p ~/.vim/pack/default/start
git clone ~/.vim/pack/default/start/vim-polyglot

NOTE: Not all features of listed language packs are available. We strip them from functionality slowing vim startup in general (for example we ignore plugins folder that is loaded regardless of file type, use ftplugin instead).

If you need full functionality of any plugin, please use it directly with your plugin manager.

Language packs

  • acpiasl (syntax)
  • ansible (syntax, indent, ftplugin)
  • apiblueprint (syntax, ctags)
  • applescript (syntax, indent)
  • arduino (syntax, indent)
  • asciidoc (syntax)
  • autohotkey (indent)
  • blade (syntax, indent, ftplugin)
  • brewfile (syntax)
  • c++11 (syntax)
  • c/c++ (syntax)
  • caddyfile (syntax, indent, ftplugin)
  • carp (syntax)
  • cjsx (syntax, ftplugin)
  • clojure (syntax, indent, autoload, ftplugin)
  • cmake (syntax, indent)
  • coffee-script (syntax, compiler, indent, autoload, ftplugin)
  • cql (syntax)
  • cryptol (syntax, compiler, ftplugin)
  • crystal (syntax, indent, autoload, ftplugin)
  • csv (syntax, autoload, ftplugin)
  • cucumber (syntax, indent, compiler, ftplugin)
  • cue (syntax)
  • dart (syntax, indent, autoload, ftplugin)
  • dhall (syntax, ftplugin)
  • dlang (syntax, indent)
  • dockerfile (syntax, indent, ftplugin)
  • elixir (syntax, indent, compiler, autoload, ftplugin)
  • elm (syntax, indent)
  • emberscript (syntax, indent, ftplugin)
  • emblem (syntax, indent, ftplugin)
  • erlang (syntax, indent)
  • ferm (syntax)
  • fish (syntax, indent, compiler, autoload, ftplugin)
  • flatbuffers (syntax)
  • fsharp (syntax, indent)
  • gdscript (syntax, indent)
  • git (syntax, indent, ftplugin)
  • glsl (syntax, indent)
  • gmpl (syntax)
  • gnuplot (syntax)
  • go (syntax, compiler, indent)
  • gradle (compiler)
  • graphql (syntax, indent, autoload, ftplugin, after)
  • haml (syntax, indent, compiler, ftplugin)
  • handlebars (syntax, indent, ftplugin)
  • haproxy (syntax)
  • haskell (syntax, indent, ftplugin)
  • haxe (syntax)
  • hcl (syntax, indent, ftplugin)
  • helm (syntax)
  • hive (syntax, ftplugin)
  • html5 (syntax, indent, autoload, ftplugin)
  • i3 (syntax, ftplugin)
  • icalenadr (syntax)
  • idris (syntax, indent, ftplugin)
  • ion (syntax, ftplugin)
  • javascript (syntax, indent, compiler, ftplugin, extras)
  • jenkins (syntax, indent)
  • jinja (syntax, indent)
  • json5 (syntax)
  • json (syntax, indent, ftplugin)
  • jst (syntax, indent)
  • jsx (autoload, after)
  • julia (syntax, indent, autoload, ftplugin)
  • kotlin (syntax, indent, ftplugin)
  • ledger (syntax, compiler, indent)
  • less (syntax, indent, ftplugin)
  • lilypond (syntax, indent, compiler, ftplugin)
  • livescript (syntax, indent, compiler, ftplugin)
  • llvm (syntax, indent, ftplugin)
  • log (syntax)
  • lua (syntax, indent)
  • mako (syntax, indent, ftplugin)
  • markdown (syntax, indent, ftplugin)
  • mathematica (syntax, ftplugin)
  • mdx (syntax)
  • meson (syntax, indent, ftplugin)
  • moonscript (syntax, indent, ftplugin)
  • nginx (syntax, indent, ftplugin)
  • nim (syntax, compiler, indent)
  • nix (syntax, indent, compiler, ftplugin)
  • objc (ftplugin, syntax, indent)
  • ocaml (syntax, indent, compiler, ftplugin)
  • octave (syntax, indent)
  • opencl (syntax, indent, ftplugin)
  • perl (syntax, indent, ftplugin)
  • pgsql (syntax, indent)
  • php (syntax)
  • plantuml (syntax, indent, ftplugin)
  • pony (syntax, indent, autoload, ftplugin)
  • powershell (syntax, indent, compiler, ftplugin)
  • protobuf (syntax, indent)
  • pug (syntax, indent, ftplugin)
  • puppet (syntax, indent, autoload, ftplugin, ctags)
  • purescript (syntax, indent, ftplugin)
  • python-compiler (compiler, autoload)
  • python-indent (indent)
  • python (syntax)
  • qmake (syntax)
  • qml (syntax, indent, ftplugin)
  • r-lang (syntax)
  • racket (syntax, indent, ftplugin)
  • ragel (syntax)
  • raku (syntax, indent, ftplugin)
  • raml (syntax, ftplugin)
  • razor (syntax, indent, ftplugin)
  • reason (syntax, indent)
  • rspec (syntax)
  • rst (syntax, indent, autoload, ftplugin)
  • ruby (syntax, indent, compiler, autoload, ftplugin)
  • rust (syntax, indent, compiler, autoload, ftplugin, ctags)
  • sbt (syntax)
  • scala (syntax, indent, compiler, ftplugin, ctags)
  • scss (syntax, indent, ftplugin)
  • sh (syntax)
  • slim (syntax, indent, ftplugin)
  • slime (syntax, indent)
  • smt2 (syntax, autoload, ftplugin)
  • solidity (syntax, indent, ftplugin)
  • stylus (syntax, indent, ftplugin)
  • svelte (syntax, indent, ftplugin)
  • svg-indent (indent)
  • svg (syntax)
  • swift (syntax, indent, compiler, ftplugin, ctags)
  • sxhkd (syntax)
  • systemd (syntax, ftplugin)
  • terraform (syntax, indent, autoload, ftplugin)
  • textile (syntax, ftplugin)
  • thrift (syntax)
  • tmux (syntax, ftplugin)
  • tomdoc (syntax)
  • toml (syntax, ftplugin)
  • tptp (syntax)
  • twig (syntax, indent, ftplugin)
  • typescript (syntax, indent, compiler, ftplugin, ctags)
  • unison (syntax)
  • v (syntax, indent, ftplugin)
  • vala (syntax, indent, ftplugin)
  • vbnet (syntax)
  • vcl (syntax)
  • vifm (syntax, autoload, ftplugin)
  • vm (syntax, indent)
  • vue (syntax, indent, ftplugin)
  • xdc (syntax)
  • xls (syntax)
  • xml (syntax)
  • yaml (syntax, ftplugin)
  • yard (syntax)
  • zephir (syntax)
  • zig (syntax, indent, autoload, ftplugin)
  • zinit (syntax)


You can either wait for new patch release with updates or run the ./build script by yourself.


Please make sure you have syntax on in your .vimrc, otherwise syntax files are not loaded at all.

Individual language packs can be disabled by setting g:polyglot_disabled as follows:

" ~/.vimrc, declare this variable before polyglot is loaded
let g:polyglot_disabled = ['css']

Note that disabling languages won’t make in general your vim startup any faster / slower (only for specific file type). Vim-polyglot is selection of language plugins that are loaded only on demand.


Language packs are periodically updated using automated build script.

Feel free to add your language, and send pull-request. In your pull request, please include:

  1. How you chose the particular repo from which to pull support for this language.
  2. An updated .
  3. If at all possible, absolutely nothing else (in particular, please don’t run build and include that in your PR).

The easier it is to validate that the new language won’t do anything wacky, the faster it’ll be merged. In particular, languages that utilize global plugins (loaded for every filetype), or plugins with dangerous features (like call based on the contents of a file being edited), will never be merged, as they will be slow or dangerous, respectively.


See linked repositories for detailed license information.