2 """This is a notmuch implementation in python. It's goal is to allow running the test suite on the cnotmuch python bindings."""
3 import sys, os, re, logging
4 from cnotmuch.notmuch import Database, Query
5 PREFIX=re.compile('(\w+):(.*$)')
6 #TODO Handle variable: NOTMUCH-CONFIG
8 #-------------------------------------------------------------------------
9 HELPTEXT="""The notmuch mail system.
11 Usage: notmuch <command> [args...]
13 Where <command> and [args...] are as follows:
15 setup Interactively setup notmuch for first use.
19 Find and import new messages to the notmuch database.
21 search [options...] <search-terms> [...]
23 Search for messages matching the given search terms.
25 show <search-terms> [...]
27 Show all messages matching the search terms.
29 count <search-terms> [...]
31 Count messages matching the search terms.
33 reply [options...] <search-terms> [...]
35 Construct a reply template for a set of messages.
37 tag +<tag>|-<tag> [...] [--] <search-terms> [...]
39 Add/remove tags for all messages matching the search terms.
43 Create a plain-text dump of the tags for each message.
47 Restore the tags from the given dump file (see 'dump').
49 search-tags [<search-terms> [...] ]
51 List all tags found in the database or matching messages.
55 This message, or more detailed help for the named command.
57 Use "notmuch help <command>" for more details on each command.
58 And "notmuch help search-terms" for the common search-terms syntax.
60 #-------------------------------------------------------------------------
61 #TODO: replace the dynamic pieces
62 USAGE="""Notmuch is configured and appears to have a database. Excellent!
64 At this point you can start exploring the functionality of notmuch by
65 using commands such as:
67 notmuch search tag:inbox
69 notmuch search to:"Sebastian Spaeth"
71 notmuch search from:"Sebastian@SSpaeth.de"
73 notmuch search subject:"my favorite things"
75 See "notmuch help search" for more details.
77 You can also use "notmuch show" with any of the thread IDs resulting
78 from a search. Finally, you may want to explore using a more sophisticated
79 interface to notmuch such as the emacs interface implemented in notmuch.el
80 or any other interface described at http://notmuchmail.org
82 And don't forget to run "notmuch new" whenever new mail arrives.
84 Have fun, and may your inbox never have much mail.
86 #-------------------------------------------------------------------------
87 def quote_query_line(argv):
88 #mangle arguments wrapping terms with spaces in quotes
89 for i in xrange(0,len(argv)):
90 if argv[i].find(' ') >= 0:
91 #if we use prefix:termWithSpaces, put quotes around term
92 m = PREFIX.match(argv[i])
94 argv[i] = '%s:"%s"' % (m.group(1), m.group(2))
96 argv[i] = '"'+argv[i]+'"'
99 if __name__ == '__main__':
101 # Handle command line options
103 if len(sys.argv) == 1:
106 elif sys.argv[1] == 'setup':
107 """ Interactively setup notmuch for first use. """
108 print "Not implemented."
110 elif sys.argv[1] == 'help':
111 if len(sys.argv) == 2: print HELPTEXT
112 else: print "Not implemented"
114 elif sys.argv[1] == 'new':
115 #TODO: handle --verbose
116 print "Not implemented."
118 elif sys.argv[1] == 'count':
120 if len(sys.argv) == 2:
121 #no further search term
124 #mangle arguments wrapping terms with spaces in quotes
125 querystr = quote_query_line(sys.argv[2:])
126 logging.debug("count "+querystr)
127 print(len(Query(db,querystr).search_messages()))
129 elif sys.argv[1] == 'search-tags':
130 if len(sys.argv) == 2:
131 #no further search term
132 print("\n".join(Database().get_all_tags()))
134 #mangle arguments wrapping terms with spaces in quotes
135 querystr = quote_query_line(sys.argv[2:])
136 logging.debug("search-term "+querystr)
138 m = Query(db,querystr).search_messages()
139 print("\n".join([t for t in m.collect_tags()]))
141 elif sys.argv[1] == 'dump':
142 #TODO: implement "dump <filename>"
145 q.set_sort(Query.SORT_MESSAGE_ID)
146 m = q.search_messages()
148 print("%s (%s)" % (msg.get_message_id(), msg.get_tags()))
152 print "Error: Unknown command '%s' (see \"notmuch help\")" % sys.argv[1]
157 search [options...] <search-terms> [...]
159 Search for messages matching the given search terms.
161 show <search-terms> [...]
163 Show all messages matching the search terms.
165 reply [options...] <search-terms> [...]
167 Construct a reply template for a set of messages.
169 tag +<tag>|-<tag> [...] [--] <search-terms> [...]
171 Add/remove tags for all messages matching the search terms.
175 Create a plain-text dump of the tags for each message.
178 search-tags [<search-terms> [...] ]
180 List all tags found in the database or matching messages.