Did you ever feel the need for some addressbook "better" than mutt's
internal alias management?
By setting $query_command in your .muttrc
you can tell mutt to use an external program for looking up addresses
when invoking the "Query" command (hit '?' for mutt-keybinding).
query_command is used as well for address completion in any prompt
for address entry, default by hitting ^T.
Selecting multiple lines in query menu
The query command can return multiple addresses. If you want to select
multiple addresses it does not work if you tag them with 't' and then
hit return. What works for me is pressing ;-m.
Use this if you want a query_command for LDAP with as few requirements as possible. Just copy and paste into your favorite text editor (be sure to check the lines ending in '' to make sure there are no extraneous spaces at the end) and save as 'mutt_ldap_search.sh' or whatever you prefer. Be sure to make it executable (chmod a+x mutt_ldap_search.sh) and add an appropriate query_command line to your .muttrc file.
This program's sole function is to perform lookups in the MacOS X Address Book and feed the results to the terminal in a format that Mutt can understand for e-mail address queries and e-mail address completion.
Query Email-Addresses, Names, and Notes from vCards (RFC 2426) stored in one or multiple directories
Useful for Address-Management Tools that use vCards as backend, e.g.: KAddressBook (KDE)
Using Multiple Query Tools
The above tools are great if all your addresses are in one place, but
what if you've got multiple sources to search? (My need for a solution
for this came from having to search the corporate LDAP directory and
Fortunately, many *nix distributions (Debian, Redhat both confirmed)
come with the perfect tool for combining these resources. Additionally,
this method can be used with the majority of the tools listed above and
with most stand-alone scripts written for mutt on the internet:
user@myhost:~/.mutt/address-providers$ pwd/home/user/.mutt/address-providersuser@myhost:~/.mutt/address-providers$ ls -ltotal 8-rwx------ 1 user user 127 2008-04-16 22:43 dummy_addresses-rwx------ 1 user user 1708 2008-04-16 18:58 mutt_ldap
user@myhost:~/.mutt/address-providers$ cat dummy_addresses#!/bin/bashecho"firstname.lastname@example.org buuuuuuuuuh HELLOOOOOOOOOOOOOOO"echo"email@example.com Roger Smith Properly Formed Entry" user@myhost:~/.mutt/address-providers$ grep query ~/.muttrcset query_command ="echo ; /bin/run-parts -a '%s' /home/user/.mutt/address-providers/|grep '@'"
To add a new search mechanism, just drop the file into the
address-providers directory. Each script in address-providers should
have a name containing only these characters: [a-zA-Z0-9-_]
take a query as its first parameter
As a result of (2), to stop any script from being used just pop a period
in its name: "mv Broken_Script Broken_Script.bother"
NB1 In my example, the "dummy_addresses" provider is there simply to
prove to yourself that the mechanism is working. Remove it after
NB2 A couple of points about the
The initial "echo;" is there because mutt doesn't use or display the first line as a potential address; it doesn't seem to be used anywhere with my fairly stock mutt install, but that doesn't mean it's useless. Change the echo statement to output anything you want
The final "grep '@'" is a nasty way of removing each script's initial reporting line that mutt would normally remove itself, as per point (1). It works as long as you're only looking for addresses that definitely use @'s, and you don't need each script's reporting line, and no reporting line contains an @. For most people, none of this is a problem - just use it as is. If you've got a problem with this, then you probably know enough to alter the command to achieve what you want ... -- jaycee