vim: more cleanup and fixes for show_next/previous handlers
authorBart Trojanowski <bart@jukie.net>
Wed, 25 Nov 2009 19:18:29 +0000 (14:18 -0500)
committerBart Trojanowski <bart@jukie.net>
Wed, 25 Nov 2009 19:18:29 +0000 (14:18 -0500)
vim/plugin/notmuch.vim

index c95e6b0e2c71abb2d2b964106770116d53a79d1d..7927dd62e77e3f685ddd3e9c3818729551337e1b 100644 (file)
@@ -410,20 +410,19 @@ function! s:NM_show_previous(can_change_thread, find_matching)
                         continue
                 endif
 
                         continue
                 endif
 
-                exec printf('norm %dG', msg['start'])
+                exec printf('norm %dGzt', msg['start'])
                 " TODO: try to fit the message on screen
                 " TODO: try to fit the message on screen
-                norm zz
                 return
         endfor
         if !a:can_change_thread
                 return
         endif
         call <SID>NM_kill_this_buffer()
                 return
         endfor
         if !a:can_change_thread
                 return
         endif
         call <SID>NM_kill_this_buffer()
-        if line('.') != line('0')
+        if line('.') > 1
                 norm k
                 call <SID>NM_search_show_thread()
                 norm G
                 norm k
                 call <SID>NM_search_show_thread()
                 norm G
-                call <SID>NM_show_previous(0)
+                call <SID>NM_show_previous(0, a:find_matching)
         else
                 echo 'No more messages.'
         endif
         else
                 echo 'No more messages.'
         endif
@@ -440,14 +439,16 @@ function! s:NM_show_next(can_change_thread, find_matching)
                         continue
                 endif
 
                         continue
                 endif
 
-                exec printf('norm %dG', msg['start'])
+                exec printf('norm %dGzt', msg['start'])
                 " TODO: try to fit the message on screen
                 " TODO: try to fit the message on screen
-                norm zz
                 return
         endfor
                 return
         endfor
-        if !a:can_change_thread
-                return
+        if a:can_change_thread
+                call <SID>NM_show_next_thread()
         endif
         endif
+endfunction
+
+function! s:NM_show_next_thread()
         call <SID>NM_kill_this_buffer()
         if line('.') != line('$')
                 norm j
         call <SID>NM_kill_this_buffer()
         if line('.') != line('$')
                 norm j
@@ -465,10 +466,6 @@ function! s:NM_show_mark_read_then_archive_thread()
         echo 'not implemented'
 endfunction
 
         echo 'not implemented'
 endfunction
 
-function! s:NM_show_next_message()
-        echo 'not implemented'
-endfunction
-
 function! s:NM_show_mark_read_then_next_open_message()
         echo 'not implemented'
 endfunction
 function! s:NM_show_mark_read_then_next_open_message()
         echo 'not implemented'
 endfunction