On Wed, 15 Oct 2014 12:33:55 -0700, Ian Main <imain@stemwinder.org> wrote: > Franz Fellner wrote: > > Here is a working implementation. > > Please review carefully as I only can simulate ruby and vimscript > > knowledge from what I see in notmuch.vim sourcefile and quick > > googling. > > Yes, this works nicely. Thanks! > > I do notice however that this is against the github plugin repo (I think)? Yes, that's right. I forked the notmuch repo on github and incorporated your patches. Already made a mistake while applying one of your patches... https://github.com/ff2000/notmuch (Hope everythin is fine now) commit cb757e9e438341a7bc6d2cfec4de7bdcc85946ea Author: Franz Fellner <alpine.art.de@gmail.com> Date: Fri Oct 17 11:19:41 2014 +0200 VIM: Add MsgID to supported URIs diff --git a/vim/notmuch.vim b/vim/notmuch.vim index 6287cf6..30e1876 100644 --- a/vim/notmuch.vim +++ b/vim/notmuch.vim @@ -268,6 +268,14 @@ ruby << EOF if uri.class == URI::MailTo vim_puts("Composing new email to #{uri.to}.") VIM::command("call s:compose('#{uri.to}')") + elsif uri.class == URI::MsgID + msg = $curbuf.message(uri.opaque) + if !msg + vim_puts("Message not found in NotMuch database: #{uri.to_s}") + else + vim_puts("Opening message #{msg.message_id} in thread #{msg.thread_id}.") + VIM::command("call s:show('thread:#{msg.thread_id}', '#{msg.message_id}')") + end else vim_puts("Opening #{uri.to_s}.") cmd = VIM::evaluate('g:notmuch_open_uri') @@ -428,11 +436,12 @@ endfunction "" main -function! s:show(thread_id) +function! s:show(thread_id, msg_id) call s:new_buffer('show') setlocal modifiable ruby << EOF thread_id = VIM::evaluate('a:thread_id') + msg_id = VIM::evaluate('a:msg_id') $cur_thread = thread_id $messages.clear $curbuf.render do |b| @@ -464,6 +473,9 @@ ruby << EOF end b << "" nm_m.end = b.count + if !msg_id.empty? and nm_m.message_id == msg_id + VIM::command("normal #{nm_m.start}zt") + end end b.delete(b.count) end @@ -486,7 +498,7 @@ ruby << EOF when 1; $cur_filter = nil when 2; $cur_filter = $cur_search end - VIM::command("call s:show('#{id}')") + VIM::command("call s:show('#{id}', '')") EOF endfunction @@ -910,6 +922,10 @@ ruby << EOF q end + def message(id) + @db.find_message(id) + end + def close @queries.delete_if { |q| ! q.destroy! } @db.close @@ -930,6 +946,13 @@ ruby << EOF end end + module URI + class MsgID < Generic + end + + @@schemes['ID'] = MsgID + end + class Message attr_accessor :start, :body_start, :end attr_reader :message_id, :filename, :mail