Add a few changes to moving between threads:

- It supports 'scrolloff' so that if you have this set it will move the
  buffer and cursor so the next/prev email starts at the top of the
  screen.
- It adds the ability to use shift-tab to go to the previous msg in
  the thread.

    Ian
---

This update fixes the commit message and removes vim_puts debugging.

 vim/notmuch.vim | 22 ++++++++++++++++++++--
 1 file changed, 20 insertions(+), 2 deletions(-)

diff --git a/vim/notmuch.vim b/vim/notmuch.vim
index 331e930..2124a8e 100644
--- a/vim/notmuch.vim
+++ b/vim/notmuch.vim
@@ -39,6 +39,7 @@ let g:notmuch_show_maps = {
        \ 'p':          'show_save_patches()',
        \ 'r':          'show_reply()',
        \ '?':          'show_info()',
+       \ '<S-Tab>':    'show_prev_msg()',
        \ '<Tab>':      'show_next_msg()',
        \ 'c':          'compose()',
        \ }
@@ -113,6 +114,22 @@ EOF
        call s:kill_this_buffer()
 endfunction

+function! s:show_prev_msg()
+ruby << EOF
+       r, c = $curwin.cursor
+       n = $curbuf.line_number
+       i = $messages.index { |m| n >= m.start && n <= m.end }
+       m = $messages[i - 1] if i > 0
+       vim_puts ("messages index is #{i} and m is #{m}")
+       if m
+               r = m.body_start + 1
+               scrolloff = VIM::evaluate("&scrolloff")
+               VIM::command("normal #{m.start + scrolloff}zt")
+               $curwin.cursor = r + scrolloff, c
+       end
+EOF
+endfunction
+
 function! s:show_next_msg()
 ruby << EOF
        r, c = $curwin.cursor
@@ -121,8 +138,9 @@ ruby << EOF
        m = $messages[i + 1]
        if m
                r = m.body_start + 1
-               VIM::command("normal #{m.start}zt")
-               $curwin.cursor = r, c
+               scrolloff = VIM::evaluate("&scrolloff")
+               VIM::command("normal #{m.start + scrolloff}zt")
+               $curwin.cursor = r + scrolloff, c
        end
 EOF
 endfunction
-- 
1.9.3

Reply via email to