diff options
author | Teddy Wing | 2020-03-21 20:55:09 +0100 |
---|---|---|
committer | Teddy Wing | 2020-03-21 20:55:09 +0100 |
commit | c08bded55f2709aa2b0bf9829c02e06684769801 (patch) | |
tree | 54ee35c5bddb5ba37b047e4ed424251d7c6da37c | |
parent | 99fe2c62624f279dc2250872da003bc43cee386b (diff) | |
parent | c7ac0e17fe4acb714b135f9b4ffac24351b3de56 (diff) | |
download | vim-twodo-c08bded55f2709aa2b0bf9829c02e06684769801.tar.bz2 |
Merge branch 'next-previous-incomplete-mappings'
-rw-r--r-- | autoload/todo/motion.vim | 24 | ||||
-rw-r--r-- | ftplugin/todo.vim | 23 |
2 files changed, 47 insertions, 0 deletions
diff --git a/autoload/todo/motion.vim b/autoload/todo/motion.vim new file mode 100644 index 0000000..32a7c88 --- /dev/null +++ b/autoload/todo/motion.vim @@ -0,0 +1,24 @@ +let s:INCOMPLETE_MATCHER = '^\s*[\-_!] ' + + +function! s:Incomplete(extra_search_flags) + let cnt = v:count1 + + let search_flags = 's' . a:extra_search_flags + + let i = 0 + while i < cnt + call search(s:INCOMPLETE_MATCHER, search_flags) + let i += 1 + endwhile +endfunction + + +function! todo#motion#NextIncomplete() + call s:Incomplete('') +endfunction + + +function! todo#motion#PreviousIncomplete() + call s:Incomplete('b') +endfunction diff --git a/ftplugin/todo.vim b/ftplugin/todo.vim index f392c94..e7664d8 100644 --- a/ftplugin/todo.vim +++ b/ftplugin/todo.vim @@ -3,6 +3,8 @@ if exists("b:did_ftplugin") endif let b:did_ftplugin = 1 +" TODO: Add no_plugin_mappings or whatever + nnoremap <silent> <buffer> <Plug>TwodoNewTodoBelow o- nnoremap <silent> <buffer> <Plug>TwodoNewTodoAbove O- @@ -13,6 +15,11 @@ nnoremap <silent> <buffer> <Plug>TwodoRemoveOldTodos :<c-u>g/^\s*[vx] /d \| nohl nnoremap <silent> <buffer> <Plug>TwodoEscalate :<c-u>call todo#Escalate()<cr> nnoremap <silent> <buffer> <Plug>TwodoDescalate :<c-u>call todo#Descalate()<cr> +nnoremap <silent> <buffer> <Plug>TwodoNextIncomplete :<c-u>call todo#motion#NextIncomplete()<cr> +nnoremap <silent> <buffer> <Plug>TwodoPreviousIncomplete :<c-u>call todo#motion#PreviousIncomplete()<cr> +onoremap <silent> <buffer> <Plug>TwodoNextIncomplete :<c-u>call todo#motion#NextIncomplete()<cr> +onoremap <silent> <buffer> <Plug>TwodoPreviousIncomplete :<c-u>call todo#motion#PreviousIncomplete()<cr> + if !hasmapto('<Plug>TwodoNewTodoBelow') || !maparg('<leader>n', 'n') nmap <silent> <buffer> <leader>n <Plug>TwodoNewTodoBelow endif @@ -44,3 +51,19 @@ endif if !hasmapto('<Plug>TwodoDescalate') || !maparg('<leader>-', 'n') nmap <silent> <buffer> <leader>- <Plug>TwodoDescalate endif + +if !hasmapto('<Plug>TwodoNextIncomplete', 'n') && !maparg(']u', 'n') + nmap <buffer> ]u <Plug>TwodoNextIncomplete +endif + +if !hasmapto('<Plug>TwodoNextIncomplete', 'o') && !maparg(']u', 'o') + omap <buffer> ]u <Plug>TwodoNextIncomplete +endif + +if !hasmapto('<Plug>TwodoPreviousIncomplete', 'n') && !maparg('[u', 'n') + nmap <buffer> [u <Plug>TwodoPreviousIncomplete +endif + +if !hasmapto('<Plug>TwodoPreviousIncomplete', 'o') && !maparg('[u', 'o') + omap <buffer> [u <Plug>TwodoPreviousIncomplete +endif |