aboutsummaryrefslogtreecommitdiffstats
path: root/vim/vimrc
diff options
context:
space:
mode:
authorMatthew Lemon <y@yulqen.org>2023-08-30 11:41:42 +0100
committerMatthew Lemon <y@yulqen.org>2023-08-30 11:41:42 +0100
commit15adfce2a7a3e1a68815528d5313ebf180c9b93d (patch)
tree4c4aee38a23ec4143767687c295ab6fce7975672 /vim/vimrc
parenta2440da186768c504919b70b188d38198a8b12d8 (diff)
More tinkering
Diffstat (limited to 'vim/vimrc')
-rw-r--r--vim/vimrc284
1 files changed, 29 insertions, 255 deletions
diff --git a/vim/vimrc b/vim/vimrc
index 1acd8a1..14cec53 100644
--- a/vim/vimrc
+++ b/vim/vimrc
@@ -41,7 +41,7 @@ set path+=**
set relativenumber
set number
set more
-set signcolumn=yes
+set signcolumn=number
set colorcolumn=0
set equalalways
set showmode
@@ -51,172 +51,43 @@ set listchars=tab:»-,trail:␣
set shortmess+=c
set tags+=./tags
set completeopt=menuone,longest
-
-" Function to allow adding a line of text to taskwarrior
-function! TaskWarriorAddCurrentLine()
- let current_line = getline('.')
- silent execute ":!task add " . shellescape(current_line)
- redraw!
- echo "Task added: " . current_line
- delete
-endfunction
-
-nnoremap <leader>q :call TaskWarriorAddCurrentLine()<CR>
-
-
-" macro to go to end of sentence and add a line break (for
-" one-line-per-sentence vimming...)
-let @s = ")i\<BS>\<CR>\<Esc>"
-
-" i don't bother with folding, but it's here if i need it.
-if has('folding')
- set foldmethod=marker
- set foldmarker=#\ {{{,#\ }}}
- set viewoptions=folds,options,cursor,unix,slash
-endif
-
-" disable folding by default with vim-markdown
-let g:vim_markdown_folding_disabled = 1
-
-" Open vimrc
-nnoremap <leader>ev <C-w>s<C-w>j<C-w>L:e $HOME/.vim/vimrc<cr>
-
-" Jump up or down by 10 lines.
-noremap <silent> J 10j
-noremap <silent> K 10k
-
-" Place timestamps, be it date (YYYY-MM-DD) or time (HH:MM:SS).
-if (exists("*strftime"))
- noremap <silent> <leader>date "=strftime("%F")<CR>p9h
- noremap <silent> <leader>time "=strftime("%X")<CR>p7h
-endif
-
-" Place timestamps, be it date (YYYY-MM-DD) or time (HH:MM:SS).
-if (exists("*strftime"))
- noremap <silent> <leader>date "=strftime("%F")<CR>p9h
- noremap <silent> <leader>time "=strftime("%X")<CR>p7h
-endif
-
-"keymap for Fern
-nnoremap ;f :Fern . -drawer<cr>
+set omnifunc=syntaxcomplete#Complete
call plug#begin()
-"Plug 'vim-scripts/AutoComplPop'
-Plug 'junegunn/fzf', { 'do': { -> fzf#install() } }
-Plug 'junegunn/fzf.vim'
-Plug 'rose-pine/vim'
-Plug 'szw/vim-maximizer'
-"Plug 'ycm-core/YouCompleteMe'
-Plug 'airblade/vim-tailwind'
-Plug 'morhetz/gruvbox'
-Plug 'lambdalisue/fern.vim'
-Plug 'junegunn/goyo.vim'
-Plug 'sheerun/vim-polyglot'
+Plug 'dense-analysis/ale'
Plug 'mhinz/vim-signify'
-Plug 'vim-test/vim-test'
-Plug 'ledger/vim-ledger'
-Plug 'fatih/vim-go', {'do': ':GoUpdateBinaries' }
Plug 'tpope/vim-dispatch'
-Plug 'tpope/vim-surround'
-Plug 'tpope/vim-commentary'
-Plug 'tpope/vim-unimpaired'
Plug 'tpope/vim-fugitive'
+Plug 'tpope/vim-commentary'
Plug 'SirVer/UltiSnips'
Plug 'honza/vim-snippets'
-Plug 'dense-analysis/ale'
-Plug 'tomasiser/vim-code-dark'
-call plug#end()
-
-" maximize current split or return to previous
-noremap <C-w>m :MaximizerToggle<CR>
-
-" vim-tailwind
-function! s:is_tailwind()
- return !empty(findfile('tailwind.config.js', '.;')) ||
- \ !empty(findfile('theme/static_src/tailwind.config.js', '.;'))
-endfunction
-
-nmap <silent> <buffer> gk <Plug>(tailwind-lookup)
-
-autocmd BufEnter *.html,*.slim if s:is_tailwind() |
- \ setlocal omnifunc=tailwind#Complete |
- \ endif
-
-" YCM
-"" *** STARTING AND ENABLING ***
-"" Don't start on start - or use show_diagnostics below
-""let g:loaded_youcompleteme = 1
-""
-"" with this set to 0, YCM doesn't load/start
-"let g:ycm_show_diagnostics_ui = 0
-"" ******************************
+Plug 'ledger/vim-ledger'
+" Plug 'sheerun/vim-polyglot'
-"let g:ycm_enable_inlay_hints = 1
-"nnoremap <silent> <localleader>h <Plug>(YCMToggleInlayHints)
-"nnoremap gd :YcmCompleter GoToDefinition<CR>
-"nnoremap <leader>gr :YcmCompleter GoToReferences<CR>
-"nnoremap K :YcmCompleter GetDoc<CR>
-"" this will disable tab, allowing it to be used for ultisnips
-"" let g:ycm_key_list_select_completion=[]
-"" let g:ycm_key_list_previous_completion=[]
-"let g:ycm_key_list_select_completion = ['<C-n>', '<Down>']
-"let g:ycm_key_list_previous_completion = ['<C-p>', '<Up>']
-"let g:ycm_python_interpreter_path = '.venv/bin/python3'
-"let g:ycm_auto_trigger = 1
-"let g:ycm_python_sys_path = []
-"let g:ycm_extra_conf_vim_data = [
-" \ 'g:ycm_python_interpreter_path',
-" \ 'g:ycm_python_sys_path'
-" \]
-""let g:ycm_global_ycm_extra_conf = '~/.global_extra_conf.py'
-"nnoremap <leader>jd :YcmCompleter GoTo<CR>
-"imap <silent> <C-l> <Plug>(YCMToggleSignatureHelp)'.
+call plug#end()
+let g:ale_linters = {'python': ['pyright', 'flake8', 'mypy'],
+\ 'javascript': ['eslint'],
+\ 'cpp': ['clangd'],
+\ 'yaml': ['yamllint'],
+\ 'c': ['clangd'],
+\ 'go': ['gopls', 'golint', 'gofmt'],
+\}
+let g:ale_fixers = {
+\ 'python': ['autoimport', 'isort', 'yapf', 'black'],
+\ 'javascript': ['eslint'],
+\ 'go': ['gofmt'],
+\ 'cpp': ['clang-format'],
+\ 'c': ['clang-format'],
+\ 'rust': ['rustfmt']
+\}
+let g:ale_fix_on_save = 1
+let g:ale_sign_column_always = 1
+set omnifunc=ale#completion#OmniFunc
-"let g:ycm_enable_inlay_hints = 0
-" ALE ale config
-" let g:ale_enabled = 1
-" let g:ale_echo_msg_format = '[%linter%] %s [%severity%]'
-" let g:ale_sign_error = '✘'
-" let g:ale_sign_warning = '⚠'
-" let g:ale_lint_on_text_changed = 0
-" let g:ale_hover_cursor = 0
-" let g:ale_virtualtext_cursor = 'disabled'
-" let g:ale_sign_column_always = 1
-" let g:ale_open_list = 0
-" let g:ale_set_highlights = 1
-" let g:ale_set_signs = 1
-" let g:ale_set_loclist = 1
-" let g:ale_set_quickfix = 1
-" let g:ale_echo_cursor = 1
-" let g:ale_echo_msg_error_str = 'Error'
-" let g:ale_echo_msg_format = '%linter% - %code: %%s'
-" let g:ale_loclist_msg_format = '%linter% - %code: %%s'
-" let g:ale_echo_msg_warning_str = 'Warning'
-" let g:ale_linters = {'python': ['pyright', 'flake8', 'mypy'],
-" \ 'ocaml': ['merlin'],
-" \ 'javascript': ['eslint'],
-" \ 'cpp': ['clangd'],
-" \ 'yaml': ['yamllint'],
-" \ 'c': ['clangd'],
-" \ 'go': ['gopls', 'golint', 'gofmt'],
-" \}
-" let g:ale_fixers = {
-" \ 'python': ['autoimport', 'isort', 'yapf', 'black'],
-" \ 'javascript': ['eslint'],
-" \ 'go': ['gofmt'],
-" \ 'cpp': ['clang-format'],
-" \ 'c': ['clang-format'],
-" \ 'rust': ['rustfmt']
-" \ }
-" let g:ale_python_mypy_ignore_invalid_syntax = 1
-" let g:ale_python_mypy_executable = 'mypy'
-" let g:ale_python_mypy_options = '--config-file mypy.ini'
-" " let g:ale_sign_error = '>>'
-" let g:ale_fix_on_save = 1
-" let g:ale_linters_explicit = 0
-" set omnifunc=ale#completion#OmniFunc
+" Open vimrc
+nnoremap <leader>ev <C-w>s<C-w>j<C-w>L:e $HOME/.vim/vimrc<cr>
" Make :grep use ripgrep
if executable('rg')
@@ -233,36 +104,6 @@ command! -bang -nargs=* Rg
nnoremap <C-p>a :Rg
-" Generate ctags for current working directory
-nnoremap <leader>tt :silent !ctags -R . <CR>:redraw!<CR>
-
-" notes stuff - from https://www.edwinwenink.xyz/posts/43-notes_tagging/
-" Go to index of notes and set working directory to my notes
-nnoremap <leader>ni :e $NOTES_DIR/index.md<CR>:cd $NOTES_DIR<CR>
-
-" 'Notes Grep' with ripgrep (see grepprg)
-" -i case insensitive
-" -g glob pattern
-" ! to not immediately open first search result
-"command! -nargs=1 Ngrep :silent grep! "<args>" -i -g '*.md' $NOTES_DIR | execute ':redraw!'
-command! -nargs=1 Ngrep vimgrep "<args>" $NOTES_DIR/**/*.md
-nnoremap <leader>nn :Ngrep
-
-" Open quickfix list in a right vertical split (good for Ngrep results)
-command! Vlist botright vertical copen | vertical resize 50
-nnoremap <leader>v : Vlist<CR>
-
-" vim-test
-nmap <silent> tn :TestNearest<CR>
-nmap <silent> tf :TestFile<CR>
-nmap <silent> ts :TestSuite<CR>
-nmap <silent> tl :TestLast<CR>
-nmap <silent> <leader>tv :TestVisit<CR>
-let test#strategy = "basic"
-let test#python#pytest#options = '-q -s'
-let test#python#runner = 'pytest'
-let test#vimterminal#term_position = "belowright"
-
" clear search highlights
nnoremap <leader><space> :noh<cr>:call clearmatches()<cr>
@@ -271,77 +112,10 @@ runtime macros/matchit.vim "allows jumping between brackets with % in normal mod
" remap :W to :w - :W was previous Windows in fzf
command! W w
-" FZF
-" This is the default extra key bindings
-let g:fzf_action = {
- \ 'ctrl-t': 'tab split',
- \ 'ctrl-x': 'split',
- \ 'ctrl-v': 'vsplit' }
-
-" - FZF Popup window (center of the screen)
-let g:fzf_layout = { 'window': { 'width': 0.9, 'height': 0.6 } }
-
-" Customize fzf colors to match your color scheme
-let g:fzf_colors =
-\ { 'fg': ['fg', '#f8f8f2'],
- \ 'bg': ['bg', '#282a36'],
- \ 'hl': ['fg', '#bd93f9'],
- \ 'fg+': ['fg', 'CursorLine', 'CursorColumn', 'Normal'],
- \ 'bg+': ['bg', 'CursorLine', 'CursorColumn'],
- \ 'hl+': ['fg', 'Statement'],
- \ 'info': ['fg', '#ffb86c'],
- \ 'prompt': ['fg', '#50fa7b'],
- \ 'pointer': ['fg', 'Exception'],
- \ 'marker': ['fg', 'Keyword'],
- \ 'spinner': ['fg', '#ffb86c'],
- \ 'header': ['fg', '#6272a4'] }
-" More fzf settings
-" (https://github.com/zenbro/dotfiles/blob/master/.nvimrc#L151-L187)
- let g:fzf_nvim_statusline = 0 " disable statusline overwriting
-
- nnoremap <C-s> :GFiles!<CR>
- nnoremap <leader><C-p> :<C-u>FZF!<CR>
- nnoremap <leader>t :Files<CR>
- nnoremap <leader>o :Tags<CR>
- nnoremap <leader>h :History<CR>
- nnoremap <silent> <leader>0 :Files<CR>
- nnoremap <silent> <leader>; :BLines<CR>
- nnoremap <silent> <leader>l :Lines<CR>
- nnoremap <silent> <leader>o :BTags<CR>
- nnoremap <silent> <leader>b :Buffers<CR>
- nnoremap <silent> <leader>? :History:<CR>
- nnoremap <silent> <leader>/ :execute 'Ag ' . input('Ag/')<CR>
- nnoremap <silent> <leader>ft :Filetypes<CR>
- nnoremap <silent> <leader>CC :Commands<CR>
- imap <C-x><C-f> <plug>(fzf-complete-file-ag)
- imap <C-x><C-l> <plug>(fzf-complete-line)
-
-
-" COLORSCHEME BITS -
-" This is imported from the old ephemera.vim file which has now been removed
-"
-" I got the following from gruvbox docs
-"Use 24-bit (true-color) mode in Vim/Neovim when outside tmux.
-"If you're using tmux version 2.2 or later, you can remove the outermost $TMUX check and use tmux's 24-bit color support
-"(see < http://sunaku.github.io/tmux-24bit-color.html#usage > for more information.)
-if (has("nvim"))
-"For Neovim 0.1.3 and 0.1.4 < https://github.com/neovim/neovim/pull/2198 >
- let $NVIM_TUI_ENABLE_TRUE_COLOR=1
-endif
-"For Neovim > 0.1.5 and Vim > patch 7.4.1799 < https://github.com/vim/vim/commit/61be73bb0f965a895bfb064ea3e55476ac175162 >
-"Based on Vim patch 7.4.1770 (`guicolors` option) < https://github.com/vim/vim/commit/8a633e3427b47286869aa4b96f2bfc1fe65b25cd >
-" < https://github.com/neovim/neovim/wiki/Following-HEAD#20160511 >
if (has("termguicolors"))
set termguicolors
endif
-"colorscheme gruber-darker
-let g:gruvbox_contrast_dark = "hard"
-let g:gruvbox_italicize_strings = 1
-let g:gruvbox_improved_strings = 1
-let g:gruvbox_improved_warnings = 1
-let g:gruvbox_invert_indent_guides = 1
-let g:gruvbox_invert_signs = 0
set background=dark
-colorscheme rosepine
-" END OF COLORSCHEME BITS -
+colorscheme gruber-darker
+