From 84f33e6546eb11a30eed74652fa408ae7ac192be Mon Sep 17 00:00:00 2001 From: Bart Trojanowski Date: Fri, 20 Nov 2009 10:57:25 -0500 Subject: [PATCH] added tagging and refresh to search screen --- vim/README | 6 +++- vim/plugin/notmuch.vim | 81 +++++++++++++++++++++++++++++++++--------- 2 files changed, 69 insertions(+), 18 deletions(-) diff --git a/vim/README b/vim/README index e4128b71..ba6eb5fe 100644 --- a/vim/README +++ b/vim/README @@ -18,7 +18,11 @@ Buffer types: Keybindings: - show the selected message - s - alter search criteria + s - enter search criteria + S - alter search criteria + + - add tag(s) to selected message + - - remove tag(s) from selected message + = - refresh display [notmuch-show] This is the display of the message. diff --git a/vim/plugin/notmuch.vim b/vim/plugin/notmuch.vim index 9e460e09..a10b9a3a 100644 --- a/vim/plugin/notmuch.vim +++ b/vim/plugin/notmuch.vim @@ -72,9 +72,10 @@ let g:notmuch_search_maps = { \ 'o': ':call NM_search_toggle_order()', \ 'r': ':call NM_search_reply_to_thread()', \ 's': ':call NM_search_prompt()', + \ 'S': ':call NM_search_edit()', \ 't': ':call NM_search_filter_by_tag()', - \ '+': ':call NM_search_add_tag()', - \ '-': ':call NM_search_remove_tag()', + \ '+': ':call NM_search_add_tags([])', + \ '-': ':call NM_search_remove_tags([])', \ '=': ':call NM_search_refresh_view()', \ } @@ -109,24 +110,34 @@ function! s:NM_cmd_search(words) setlocal nowrap endfunction +" --- --- search screen action functions {{{2 + function! s:NM_search_show_thread() - if !exists('b:nm_raw_lines') - echo 'no b:nm_raw_lines' - else - let line = line('.') - let info = b:nm_raw_lines[line-1] - let what = split(info, '\s\+')[0] - call s:NM_cmd_show([what]) + let id = NM_search_find_thread_id() + if id != '' + call s:NM_cmd_show([id]) endif endfunction function! s:NM_search_prompt() - let new_list = input('NotMuch Search: ', join(g:notmuch_current_search_words, ' ')) - call NM_cmd_search(split(new_list)) + " TODO: input() can support completion + let text = input('NotMuch Search: ') + if strlen(text) + call NM_cmd_search(split(text)) + endif +endfunction + +function! s:NM_search_edit() + " TODO: input() can support completion + let text = input('NotMuch Search: ', join(g:notmuch_current_search_words, ' ')) + if strlen(text) + call NM_cmd_search(split(text)) + endif endfunction function! s:NM_search_archive_thread() - echoe 'Not implemented' + call NM_search_remove_tags('inbox') + norm j endfunction function! s:NM_search_filter() @@ -149,18 +160,54 @@ function! s:NM_search_filter_by_tag() echoe 'Not implemented' endfunction -function! s:NM_search_add_tag() - echoe 'Not implemented' +function! s:NM_search_add_tags(tags) + call NM_search_add_remove_tags('Add Tag(s): ', '+', a:tags) endfunction -function! s:NM_search_remove_tag() - echoe 'Not implemented' +function! s:NM_search_remove_tags(tags) + call NM_search_add_remove_tags('Remove Tag(s): ', '-', a:tags) endfunction function! s:NM_search_refresh_view() - echoe 'Not implemented' + let lno = line('.') + call s:NM_cmd_search(g:notmuch_current_search_words) + " FIXME: should find the line of the thread we were on if possible + exec printf('norm %dG', lno) endfunction +" --- --- search screen helper functions {{{2 + +function! s:NM_search_find_thread_id() + if !exists('b:nm_raw_lines') + echoe 'no b:nm_raw_lines' + return '' + else + let line = line('.') + let info = b:nm_raw_lines[line-1] + let what = split(info, '\s\+')[0] + return what + endif +endfunction + +function! s:NM_search_add_remove_tags(prompt, prefix, intags) + let id = NM_search_find_thread_id() + if id != '' + if type(a:intags) != type([]) || len(a:intags) == 0 + " TODO: input() can support completion + let text = input(a:prompt) + if !strlen(text) + return + endif + let tags = split(text, ' ') + else + let tags = a:intags + endif + call map(tags, 'a:prefix . v:val') + " TODO: handle errors + call NM_run(['tag'] + tags + ['--', id]) + call NM_search_refresh_view() + endif +endfunction " --- implement show screen {{{1 -- 2.26.2