From: Franz Fellner <alpine.art.de@gmail.com>
To: Tomi Ollila <tomi.ollila@iki.fi>, Tomi Ollila <tomi.ollila@iki.fi>
Cc: notmuch@notmuchmail.org
Subject: Re: [PATCH] VIM: Add URI handling
Date: Mon, 20 Oct 2014 21:38:54 +0200 [thread overview]
Message-ID: <544564ceae3dc_25b371be984d@TP_L520.notmuch> (raw)
In-Reply-To: <m2vbner283.fsf@guru.guru-group.fi>
Tomi Ollila wrote:
> On Fri, Oct 17 2014, Franz Fellner <alpine.art.de@gmail.com> wrote:
>
> > 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
>
> Code-wise this patch looks good -- although I am not entirely sure what id
> does -- I expect it to handle id:... links...
Yes, that's what it should do.
> This email applies with git am (on top of Ian's) but the commit message has
> quite a few lines of cruft -- I'd like to see a commit message what
> explains what this change do ( the term 'MsgID' seems to be some vim client
> internal (subclass in URI class ?) which IMO should be better commented in
> this commit message.
MsgID was just a short name for message-id, and I am used to CamelCase...
VIM: Add support to open messages specified by their message-id in notmuch-show.
Does that make more sense?
> Tomi
>
> >
> > 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
> > _______________________________________________
> > notmuch mailing list
> > notmuch@notmuchmail.org
> > http://notmuchmail.org/mailman/listinfo/notmuch
next prev parent reply other threads:[~2014-10-20 19:38 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-10-02 20:23 [PATCH] VIM: Add URI handling Ian Main
2014-10-10 9:44 ` Franz Fellner
2014-10-10 18:18 ` Ian Main
2014-10-11 12:29 ` Franz Fellner
2014-10-15 19:33 ` Ian Main
2014-10-17 16:14 ` Franz Fellner
2014-10-20 17:45 ` Ian Main
2014-10-20 19:05 ` Tomi Ollila
2014-10-20 19:38 ` Franz Fellner [this message]
2014-10-21 14:25 ` Tomi Ollila
2014-10-20 18:53 ` Tomi Ollila
2014-10-23 22:19 ` [PATCH v2] " Ian Main
2014-10-24 9:52 ` Tomi Ollila
2014-10-24 16:11 ` [PATCH v3] " Ian Main
2014-10-24 16:30 ` Tomi Ollila
2014-10-24 17:03 ` Ian Main
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://notmuchmail.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=544564ceae3dc_25b371be984d@TP_L520.notmuch \
--to=alpine.art.de@gmail.com \
--cc=notmuch@notmuchmail.org \
--cc=tomi.ollila@iki.fi \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://yhetil.org/notmuch.git/
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).