From: Alexander Baier <lexi.baier@gmail.com>
To: Eric Abrahamsen <eric@ericabrahamsen.net>
Cc: ding@gnus.org
Subject: Re: Create a group from a list of message-ids
Date: Sat, 30 Nov 2013 19:56:28 +0100 [thread overview]
Message-ID: <87d2lh3ehv.fsf@gmail.com> (raw)
In-Reply-To: <87eh5zg9i5.fsf@ericabrahamsen.net> (Eric Abrahamsen's message of "Fri, 29 Nov 2013 10:41:22 +0700")
On 13-11-29 04:41 Eric Abrahamsen wrote:
> Alexander Baier <lexi.baier@gmail.com> writes:
>
>> On 13-11-26 05:06 Eric Abrahamsen wrote:
>>> Frank Terbeck <ft@bewatermyfriend.org> writes:
>>>
>>>> Eric Abrahamsen wrote:
>>>> [...]
>>>>> It also comes with its own tagging structure and all kinds of stuff I
>>>>> don't use. The superfluity bugs me a little, but the searching is nice
>>>>> enough that it doesn't matter. A nnir plugin for notmuch might actually
>>>>> be nice.
>>>>
>>>> Actually, at least in the git version of gnus, ‘nnir’ seems to feature
>>>> support for ‘notmuch’ (ie. there is a defcustom ‘nnir-notmuch-program’
>>>> and a defun ‘nnir-run-notmuch’).
>>>>
>>>> Since ‘mu’ seems to work fairly similarly to notmuch, I would guess
>>>> that, this part would serve as a source for ideas for ‘mu’-integration.
>>>>
>>>> Regards, Frank
>>>
>>> Thanks to both of you for pointing that out! I had no idea that was
>>> there, but would definitely prefer using a more gnus-y interface. I set
>>> it up like so:
>>>
>>> (setq nnir-method-default-engines '((nnimap . notmuch) (nntp . gmane)))
>>>
>>> And gave it a shot.
>>>
>>> It didn't work for me for two reasons. I have several different imap
>>> servers, all run through dovecot with a maildir structure. They're all
>>> under ~/.mail, like ~/.mail/acc1 ~/mail/acc2 etc. That means
>>> nnir-notmuch-remove-prefix has to be set to an appropriate value for
>>> each server, which you can do with server parameters. But that means you
>>> can only search one server at a time (which I guess you'd do by putting
>>> a notmuch-group key into the query? I don't even know how to do that).
>>> That isn't really what I want -- I'd like to search all my mail at once.
>>> And even if I had to do it server by server, it seems like
>>> `nnir-run-notmuch' should be able to figure out how to filter to that
>>> server by itself...
>
> [...]
>
>> Hi Eric,
>>
>> I am digging this up again, as I had some time to look at this myself
>> and maybe have an idea of how to tackle this problem.
>>
>> Now, as I see it, the thing preventing us from searching multiple
>> servers is the fact that nnir-compose-result might be passed a server
>> that does not fit to the matched article as this may come from a
>> different server. So I think, solving this problem is "just" a matter
>> of teaching nnir-compose-result to correct the server it is passed in
>> case it does not fit to the matched article. For nnir-compose-result to
>> be able to so we need to tell it how to extract the server from the
>> dirnam parameter. The question is, how do we tell nnir-compose-result
>> this? Do you have any ideas on this?
>
> Right now, servers to search are chosen with
> `gnus-group-make-nnir-group', which does one of three things:
>
> 1. Extracts the server from the group under point
> 2. Extracts server from the marked groups, if groups are marked
> 3. If we're in the *Server* buffer, use the server under point
>
> Options one and three obviously only provide a single server, option two
> results in something like this (I marked the INBOXs of three different accounts):
>
> (("nnimap:acc1" ("nnimap+acc1:INBOX"))
> ("nnimap:acc2" ("nnimap+acc2:INBOX"))
> ("nnimap:acc3" ("nnimap+acc3:INBOX")))
>
> What eventually happens is that `nnir-run-query' loops
> over each server in the above sexp (ignoring the group), and calls
> `nnir-run-notmuch' once for each server. Each loop passes the same
> search results to `nnir-compose-results', which filters the results
> based on the current server.
>
> So theoretically if you'd marked one group from each of the accounts you
> wanted to search, you'd get full results. We should be able to do the
> same thing by wrapping `gnus-group-make-nnir-group' and force-feeding it
> arguments:
>
> (setq notmuch-servers-to-search '(("nnimap:acc1")
> ("nnimap:acc2")
> ("nnimap:acc3")))
>
> (defun nnir-search-all-servers (&optional query-spec)
> (interactive)
> (setq query-spec (or query-spec
> (list (cons 'query
> (read-string "Query: " nil 'nnir-search-history)))))
> (gnus-group-make-nnir-group
> nil (list
> (cons 'nnir-query-spec query-spec)
> (cons 'nnir-group-spec notmuch-servers-to-search))))
>
>
> Can you set notmuch-servers-to-search appropriately, and test that? It's
> hard for me to test as I'm still having the "is it maildir or isn't it"
> problem, as well as the "I don't have an INBOX" problem.
>
> Thanks,
> Eric
>
>
>
Hi Eric,
I tested your code and it seems to do exactly what you are describing.
There is, however, another problem I am facing, that produces a nil as
article number in some or all of the results (vectors with 3 elements)
returned by nnir-compose-result. I have not figured out how to solve
this but will follow up as soon as I find something.
So long,
--
Alexander Baier
next prev parent reply other threads:[~2013-11-30 18:56 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-23 11:50 Alexander Baier
2013-11-25 2:02 ` Dave Goldberg
2013-11-25 8:52 ` Alexander Baier
2013-11-25 8:58 ` Frank Terbeck
2013-11-25 9:11 ` Alexander Baier
2013-11-25 9:01 ` Eric Abrahamsen
2013-11-25 9:13 ` Alexander Baier
2013-11-25 13:20 ` Eric Abrahamsen
2013-11-25 14:08 ` Alexander Baier
2013-11-25 15:26 ` Eric Abrahamsen
2013-11-25 15:44 ` Frank Terbeck
2013-11-26 4:06 ` Eric Abrahamsen
2013-11-27 5:16 ` Eric Abrahamsen
2013-11-27 7:34 ` Alexander Baier
2013-11-27 8:10 ` Eric Abrahamsen
2013-11-27 8:22 ` Alexander Baier
2013-11-28 12:02 ` Alexander Baier
2013-11-29 3:41 ` Eric Abrahamsen
2013-11-30 18:56 ` Alexander Baier [this message]
2013-11-25 16:11 ` Alexander Baier
2013-11-25 9:28 ` Pedro Silva
2013-11-25 9:44 ` Alexander Baier
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
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87d2lh3ehv.fsf@gmail.com \
--to=lexi.baier@gmail.com \
--cc=ding@gnus.org \
--cc=eric@ericabrahamsen.net \
/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.
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 NNTP newsgroup(s).