Custom Neovim Haskell Scripts

root

Syntax Highlighting and Indentation for Haskell and Cabal

I was unhappy with the Haskell scripts that are shipped with vim, therefore I decided to make my own based on idris-vim.

I hope you find this useful.

Screenshot

Screenshot

Features

  • Covers a broader spectrum of keywords
  • Highlighting for new features like type families, pattern synonyms, arrow syntax, recursive do, role annotations, QuasiQuotation
  • More contextual highlighting (e.g. highlight 'as' or 'family' only in appropriate places)
  • Smarter indentation
  • Better Cabal support

Installation

I recommend using Pathogen for installation. Simply clone this repo into your ~/.vim/bundle directory and you are ready to go.

cd ~/.vim/bundle
git clone https://github.com/neovimhaskell/haskell-vim.git

Be sure that the following lines are in your .vimrc

syntax on
filetype plugin indent on

Manual Installation

Copy content into your ~/.vim directory.

Configuration

Features

To enable the features you would like to use, just add the according line to your .vimrc.

let g:haskell_enable_quantification = 1   " to enable highlighting of `forall`
let g:haskell_enable_recursivedo = 1      " to enable highlighting of `mdo` and `rec`
let g:haskell_enable_arrowsyntax = 1      " to enable highlighting of `proc`
let g:haskell_enable_pattern_synonyms = 1 " to enable highlighting of `pattern`
let g:haskell_enable_typeroles = 1        " to enable highlighting of type roles
let g:haskell_enable_static_pointers = 1  " to enable highlighting of `static`
let g:haskell_backpack = 1                " to enable highlighting of backpack keywords

Highlighting

haskell-vim has an opinionated highlighting. If you do not like that you can switch to a more traditional mode by setting g:haskell_classic_highlighting to 1.

Disabling Template Haskell and Quasiquoting syntax is possible by setting g:haskell_disable_TH to 1.

Indentation

To configure indentation in haskell-vim you can use the following variables to change indentation depth, just add the according line to your .vimrc.

If you dislike how indentation works you can disable it by setting g:haskell_indent_disable to 1.

Additionally you can use the vim-hindent plugin to achieve automatic indentation using hindent.

Haskell

  • let g:haskell_indent_if = 3

    if bool
    >>>then ...
    >>>else ...
  • let g:haskell_indent_case = 2

    case xs of
    >>[]     -> ...
    >>(y:ys) -> ...
  • let g:haskell_indent_let = 4

    let x = 0 in
    >>>>x
  • let g:haskell_indent_where = 6

    where f :: Int -> Int
    >>>>>>f x = x
  • let g:haskell_indent_before_where = 2

    foo
    >>where
  • let g:haskell_indent_after_bare_where = 2

    where
    >>foo
  • let g:haskell_indent_do = 3

    do x <- a
    >>>y <- b
  • let g:haskell_indent_in = 1

    let x = 1
    >in x
  • let g:haskell_indent_guard = 2

    f x y
    >>|

haskell-vim also supports an alterative style for case indentation.

  • let g:haskell_indent_case_alternative = 1

    f xs ys = case xs of
    >>[]     -> ...
    >>(y:ys) -> ...

Cabal

  • let g:cabal_indent_section = 2 (limited to max. 4 spaces)

    executable name
    >>main-is:             Main.hs