setlocal ts=2 sw=2 expandtab "set background=light "set guifont=Neep\ Medium\ Semi-Condensed\ 18 " 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 cgd :Tags =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 " nnoremap ld :call LanguageClient#textDocument_definition() " nnoremap lr :call LanguageClient#textDocument_rename() " nnoremap lf :call LanguageClient#textDocument_formatting() " nnoremap lt :call LanguageClient#textDocument_typeDefinition() " nnoremap lx :call LanguageClient#textDocument_references() " nnoremap la :call LanguageClient_workspace_applyEdit() " nnoremap lc :call LanguageClient#textDocument_completion() " nnoremap lh :call LanguageClient#textDocument_hover() " nnoremap ls :call LanguageClient_textDocument_documentSymbol() " nnoremap lm :call LanguageClient_contextMenu() " nnoremap :call LanguageClient#textDocument_hover() " deoplete "call deoplete#custom#option('sources',{ " \ '_': ['buffer'], " \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] " \ }) " " \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] "call deoplete#enable() "call deoplete#enable_logging('DEBUG', $HOME . '/deoplete.log') "" inoremap pumvisible() ? "\" : "\" 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' : ['.']} " let g:ycm_language_server = [ { 'name': 'haskell', 'filetypes': [ 'haskell', 'hs', 'lhs' ], 'cmdline': [ 'hie-wrapper' ], 'project_root_files': [ '.stack.yaml', 'cabal.config', 'package.yaml', 'cabal.project' ] } ] " 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 let g:neoformat_enabled_haskell = ['brittany'] " map t InteroGenericType " nnoremap jd :InteroGoToDef " map T InteroType " nnoremap it :InteroTypeInsert " nnoremap ist :InteroSetTargets " endif " LSP let g:LanguageClient_rootMarkers = ['cabal.project', '*.cabal', 'stack.yaml'] " \ 'haskell': ['ghcide', "--lsp"], let g:LanguageClient_serverCommands = { \ 'haskell': ['hie-wrapper', '--lsp'], \ } let g:echodoc#enable_at_startup = 1 call deoplete#enable() call deoplete#custom#source('LanguageClient', \ 'min_pattern_length', \ 2) inoremap pumvisible() ? "\" : "\"