setlocal ts=2 sw=2 expandtab "set background=light "set guifont=Neep\ Medium\ Semi-Condensed\ 18 syntax on filetype plugin indent on " tags call CmdAlias('hasktags', '!hasktags -c .') " from " https://raw.githubusercontent.com/begriffs/haskell-vim-now/master/git-hscope call CmdAlias('codex', 'call system("haskell-ctags")call LoadHscope()') map ctg :codex set tags=tags;/,codex.tags;/ " classic ctags jump nnoremap gd nnoremap cgd :cs find g =expand("") nnoremap :cs find c =expand("") set cscopeprg=do_at_stack_root\ hscope set csre set csto=1 " search codex tags first set nocst " set cscopequickfix=s-,c-,d-,i-,t-,e-,a- function! LoadHscope() set nocscopeverbose " suppress 'duplicate connection' error let hsf = findfile("hscope.out", ".;") if filereadable(hsf) exe "cs add " . hsf elseif $HSCOPE_DB != "" cs add $HSCOPE_DB endif set cscopeverbose endfunction au BufEnter /*.hs call LoadHscope() "hoogle nnoremap ho :Hoogle nnoremap hc :HoogleClose " haskell-vim let g:haskell_classic_highlighting = 1 let g:haskell_indent_disable = 1 " let g:haskell_enable_quantification = 1 " let g:haskell_enable_recursivedo = 1 " let g:haskell_enable_arrowsyntax = 1 " let g:haskell_enable_pattern_synonyms = 1 " let g:haskell_enable_typeroles = 1 " let g:haskell_indent_if = 3 " let g:haskell_indent_case = 5 " let g:haskell_indent_let = 4 " let g:haskell_indent_where = 6 " let g:haskell_indent_do = 3 " let g:haskell_indent_in = 1 " haskellmode-vim function! HaskellDocCurrentWord() let word = expand("") exe "IDoc " . word endfunction " done by LSP now nmap :call HaskellDocCurrentWord() nmap :silent update HsimportModule nmap :silent update HsimportSymbol " liquid-types let g:vim_annotations_offset = '/.liquid/' " autocmd BufWritePost *.hs call s:check_and_lint() " function! s:check_and_lint() " let l:path = expand('%:p') " let l:qflist = ghcmod#make('check', l:path) " call extend(l:qflist, ghcmod#make('lint', l:path)) " call setqflist(l:qflist) " cwindow " if empty(l:qflist) " echo "No errors found" " endif " endfunction " LSP let g:LanguageClient_autoStart = 0 let g:LanguageClient_serverCommands = { \ 'haskell': ['hie-wrapper', '--lsp', '-d', '-l', $HOME.'/lang-server.log'], \ } " we use ALE instead let g:LanguageClient_diagnosticsEnable = 0 nnoremap lc :call LanguageClient_contextMenu() " nnoremap gd :call LanguageClient#textDocument_definition() nnoremap :call LanguageClient#textDocument_hover() vnoremap :call LanguageClient#textDocument_hover() nnoremap :call LanguageClient#textDocument_rename() " deoplete call deoplete#custom#option('sources',{ \ '_': ['buffer'], \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] \ }) " \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] " inoremap pumvisible() ? "\" : "\" call deoplete#enable() call deoplete#enable_logging('DEBUG', $HOME . '/deoplete.log') let g:ghcmod_hlint_options = ['--ignore=Eta reduce $'] " ALE let g:ale_enabled = 0 let g:ale_linters = {'haskell':[], 'c':['clang']} " let g:ale_linters = {'haskell':['ghc-mod', 'hdevtools', 'argon'], 'c':['clang']} " let g:ale_fixers = { " \ 'haskell': ['brittany'], " \} let g:ale_haskell_hdevtools_options = "-g '-Wall' -g '-Wno-orphans'" let g:ale_haskell_argon_error_level = 14 let g:ale_haskell_argon_warn_level = 10 let g:ale_haskell_argon_info_level = 6 " completion " " neco-ghc " let g:necoghc_enable_detailed_browse = 1 " let g:haskellmode_completion_ghc = 0 " autocmd FileType haskell setlocal omnifunc=necoghc#omnifunc " let g:ycm_semantic_triggers = {'haskell' : ['.']} " clear search nmap :noh:GhcModTypeClear imap :noh:GhcModTypeClear " unmap " unmap nmap :GhcModType " for intero " if has("nvim") " let g:ale_enabled = 0 " " let g:intero_backend = { " " \ 'command': 'cabal new-repl', " " \ 'options': '', " " \ 'cwd': expand('%:p:h'), " " \} " " Intero starts automatically. Set this if you'd like to prevent that. " let g:intero_start_immediately = 1 " " Enable type information on hover (when holding cursor at point for ~1 second). " let g:intero_type_on_hover = 1 " " Change the intero window size; default is 10. " let g:intero_window_size = 15 " " Sets the intero window to split vertically; default is horizontal " " let g:intero_vertical_split = 1 " " let g:intero_ghci_options = '-dynamic' " " OPTIONAL: Make the update time shorter, so the type info will trigger faster. " set updatetime=1000 " map t InteroGenericType " nnoremap jd :InteroGoToDef " map T InteroType " nnoremap it :InteroTypeInsert " nnoremap ist :InteroSetTargets " endif