reverse order so that the latest is at top
[notmuch] / vim / plugin / notmuch.vim
index 865624fed01c698e90797b2894109d1c2ff29244..00ee98427ccca5269eba347f8d1265d02bf11b67 100644 (file)
@@ -25,18 +25,30 @@ if !exists('g:notmuch_cmd')
         let g:notmuch_cmd = 'notmuch'
 endif
 
+if !exists('g:notmuch_search_reverse')
+        let g:notmuch_search_reverse = 1
+endif
 
 " --- implement search screen
 
 function! s:NM_cmd_search(words)
-        let data = split(s:NM_run(['search'] + a:words), "\n")
-        let disp = copy(data)
+        let cmd = ['search']
+        if g:notmuch_search_reverse
+                let cmd = cmd + ['--reverse']
+        endif
+        let data = s:NM_run(cmd + a:words)
+        "let data = substitute(data, '27/27', '25/27', '')
+        "let data = substitute(data, '\[4/4\]', '[0/4]', '')
+        let lines = split(data, "\n")
+        let disp = copy(lines)
         call map(disp, 'substitute(v:val, "^thread:\\S* ", "", "")' )
 
         call s:NM_newBuffer('search', join(disp, "\n"))
-        let b:nm_raw_data = data
+        let b:nm_raw_data = lines
 
         nnoremap <buffer> <Enter> :call <SID>NM_search_display()<CR>
+        setlocal cursorline
+        setlocal nowrap
 endfunction
 
 function! s:NM_search_display()
@@ -45,7 +57,7 @@ function! s:NM_search_display()
                 echo 'no b:nm_raw_data'
         else
                 let info = b:nm_raw_data[line]
-                let what = split(info, '\W\+')[0]
+                let what = split(info, '\s\+')[0]
                 call s:NM_cmd_show([what])
         endif
 endfunction
@@ -54,10 +66,14 @@ endfunction
 " --- implement show screen
 
 function! s:NM_cmd_show(words)
+        let bufnr = bufnr('%')
         let data = s:NM_run(['show'] + a:words)
 
         call s:NM_newBuffer('show', data)
+        setlocal bufhidden=delete
         let b:nm_raw_data = data
+
+        exec printf("nnoremap <buffer> q :b %d<CR>", bufnr)
 endfunction
 
 
@@ -66,12 +82,11 @@ endfunction
 function! s:NM_newBuffer(ft, content)
         enew
         setlocal buftype=nofile readonly modifiable
-        setlocal bufhidden=delete
         silent put=a:content
         keepjumps 0d
         setlocal nomodifiable
-        setlocal cursorline
-        execute printf('setlocal filetype=notmuch-%s', a:ft)
+        execute printf('set filetype=notmuch-%s', a:ft)
+        execute printf('set syntax=notmuch-%s', a:ft)
 endfunction
 
 function! s:NM_run(args)