aboutsummaryrefslogtreecommitdiffhomepage
Commit message (Collapse)AuthorAge
* Rename sha1.c to libsha1.cGravatar Carl Worth2009-10-21
| | | | | | | | | This way both the .c and .h files have the same name, and all of the code imported from the "libsha1" implementation is in filenames matching libsha1.*. This also gives me room to make my own notmuch_sha1 wrapper functions in sha1.c.
*-. Merge branch from fixing up bugs after bisecting.Gravatar Carl Worth2009-10-21
|\ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | I'm glad that when I implemented "notmuch restore" I went through the extra effort to take the code I had written in one sitting into over a dozen commits. Sure enough, I hadn't tested well enough and had totally broken "notmuch setup", (segfaults and bogus thread_id values). With the little commits I had made, git bisect saved the day, and I went back to make the fixes right on top of the commits that introduced the bugs. So now we octopus merge those in.
| | * Bring back the insert_thread_id function.Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We deleted this in favor of our fancy new thread_ids iterator from the message object. But one of the previous callers of insert_thread_id isn't using notmuch_message_t yet. I made the mistake of thinking I could just call g_hash_table_insert directly, but the problem was that nobody was splitting up the thread_id string at its commas. So with this, we were inserting bogus comma-separated IDs into the hash table, so thread_id values were ballooning out of control. Should be much better now.
| * | Fix lifetime-maintenance bug with std::string and c_str()Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Here's more evidence that C++ is a nightmare to program---or that I'm smart enough to realize that C++ is more clever than I will ever be. Most of my issues with C++ have to do with it hiding things from me that I'd really like to and expect to be aware of as a C programmer. For example, the specific problem here is that there's a short-lived std::string, from which I just want to copy the C string. I try to do that on the next line, but before I can, C++ has already called the destructor on the std::string. Now, C++ isn't alone in doing garbage collecting like this. But in a *real* garbage-collecting system, everything would work that way. For example, here, I'm still holding a pointer to the C string contents, so if the garbage collector were aware of that reference, then it might clean up the std::string container and leave the data I'm still using. But that's not what we get with C++. Instead, some things are reference counted and collected, (like the std::string), and some things just aren't (like the C string it contains). The end result is that it's very fragile. It forces me to be aware of the timing of hidden functions. In a "real" system I wouldn't have to be aware of that timing, and in C the function just wouldn't be hidden.
* | | List a few more co-conspirators.Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | | | | | | | Keith's name already shows up in the git log, so it would be wrong to not mention him. And Martin and Jamey have been helpful in discussions about what an ideal mail system would look like.
* | | Add an AUTHORS file.Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | Now that I've copied in another source file from someone else, I want to be sure I'm keeping a good list of everyone who has helped.
* | | Add sha1.c and libsha1.h for doing SHA-1-based message-ID generation.Gravatar Mikhail Gusarov2009-10-21
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This code comes courtesy of Brian Gladman and Mikhail Gusarov. Both files are available under the GPL and were downloaded as version 0.2 of libsha1 from git://github.com/dottedmag/libsha1.git with the following commit: commit d0f0e7e0dc5ce2d58972cb5a492183c0d4e58433 Author: Mikhail Gusarov <dottedmag@dottedmag.net> Date: Mon Oct 20 22:38:47 2008 +0700 Version bump. Signed-off-by: Mikhail Gusarov <dottedmag@dottedmag.net>
* | | Add copy of GNU General Public License (version 3).Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | All the files were already advertising the license, but we didn't actually have a copy of the license in the repository until now.
* | | Add notmuch_status_to_string function.Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | Be kind and let the user print error messages, not just error codes.
* | | Implement "notmuch restore".Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | | | | It's pretty easy to do with all the right infrastructure in place. Now that I can get my tags from sup to notmuch, maybe I'll be able to start reading mail again.
* | | Pull out a chomp_newline function from "notmuch setup"Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | We'll want this same thing with "notmuch restore", (and really anything using getline).
* | | Add notmuch_message_add_tag and notmuch_message_remove_tagGravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | With these two added, we now have enough functionality in the library to implement "notmuch restore".
* | | notmuch-private.h: Move NOTMUCH_BEGIN_DECLS earlierGravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | | | | | | | We actually need this before the include of xutil.h, but it was previously stuck randomly among various system includes. Instead, put it at the top, right after include the notmuch.h header that defines it.
* | | notmuch_query_search: Clarify the documentation.Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | | | | | | | | | | This is where we wanted to put the note to recommend the user call notmuch_message_destroy if the lifetime of the message is much shorter than the lifetime of the query. (Somehow this had ended up in the documentation of notmuch_message_get_tags before.)
* | | notmuch.h: Fix some copy-paste errors in the documentaton.Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | | | In several places we had "results" where "tags" was intended. It actually read fine in some cases, but this is still better.
* | | notmuch_message_get_message_id: Fix to cache resultGravatar Carl Worth2009-10-21
| |/ |/| | | | | | | | | | | | | | | Previously, this would allocate new memory with every call. That was with talloc, of course, so there wasn't any leaking (eventually). But since we're now calling this internally we want to be a little less wasteful. It's easy enough to just stash the result into the message on the first call, and then just return that on subsequent calls.
* | database: Add new notmuch_database_find_messageGravatar Carl Worth2009-10-21
|/ | | | | | | With this function, and the recently added support for notmuch_message_get_thread_ids, we now recode the find_thread_ids function to work just the way we expect a user of the public notmuch API to work. Not too bad really.
* Add notmuch_message_get_thread_ids functionGravatar Carl Worth2009-10-21
| | | | | | Along with all of the notmuch_thread_ids_t iterator functions. Using a consistent idiom seems better here rather than returning a comma-separated string and forcing the user to parse it.
* Add wrappers for regcomp and regexec to xutil.c.Gravatar Carl Worth2009-10-21
| | | | These will be handy for some parsing.
* Rename NOTMUCH_MAX_TERM to NOTMUCH_TERM_MAXGravatar Carl Worth2009-10-21
| | | | Just better consistency with our naming schemes.
* Move find_prefix function from database.cc to message.ccGravatar Carl Worth2009-10-21
| | | | | | It's definitely a better fit there for now, (and can likely eventually be made static as add_term moves from database to message as well).
* notmuch dump: Fix to print spaces between tags.Gravatar Carl Worth2009-10-21
| | | | Simple little bug here made all the tags run together.
* Convert notmuch_database_t to start using talloc.Gravatar Carl Worth2009-10-21
| | | | | This will be handy as we can hang future talloc allocations off of the datbase now.
* Move declarations for xutil.c from notmuch-private to new xutil.h.Gravatar Carl Worth2009-10-21
| | | | | | | The motivation here is that our top-level notmuch.c main program wants to start using these, but we don't want it to see into notmuch-private.h, (since our main program is a test vehicle for the "public" notmuch interface in notmuch.h).
* notmuch dump: Fix buffer overrun in error message.Gravatar Carl Worth2009-10-21
| | | | Just a little bug I noticed while editing nearby code.
* notmuch setup: Collapse internal whitespace within message-idGravatar Carl Worth2009-10-21
| | | | | | | I'm too lazy to see what the RFC says, but I know that having whitespace inside a message-ID is sure to confuse things. And besides, this makes things more compatible with sup so that I have some hope of importing sup labels.
* notmuch dump: Fix the sorting of results.Gravatar Carl Worth2009-10-21
| | | | | | | | | | | | | To properly support sorting in notmuch_query we know use an Enquire object. We also throw in a QueryParser too, so we're really close to being able to support arbitrary full-text searches. I took a look at the supported QueryParser syntax and chose a set of flags for everything I like, (such as supporting Boolean operators in either case ("AND" or "and"), supporting phrase searching, supporting + and - to include/preclude terms, and supporting a trailing * on any term as a wildcard).
* add_message: Add a type:mail ("Kmail") term to all documents.Gravatar Carl Worth2009-10-21
| | | | | This gives us an easy way to specify "all mail messages" in a search query. We simply look for this term.
* notmuch setup: Print a few protecting spaces after progress reports.Gravatar Carl Worth2009-10-21
| | | | | | | | | | This is to help keep the report looking clean when a new report is shorter than a previous reports, (say, when crossing the boundary from over one minute remaining to less than one minute remaining). This used to be here, but I must have accidentally dropped it when reformatting the progress report recently.
* .gitignore: Ignore generated file Makefile.depGravatar Carl Worth2009-10-20
| | | | | Forgot to add this when I first add dependency checking to the Makefile.
* database: Remove two little bits of dead code.Gravatar Carl Worth2009-10-20
|
* query: Remove the magic NOTMUCH_QUERY_ALLGravatar Carl Worth2009-10-20
| | | | | | | Using the address of a static char* was clever, but really unnecessary. An empty string is much less magic, and even easier to understand as the way to query everything from the database.
* notmuch dump: Free each message as it's used.Gravatar Carl Worth2009-10-20
| | | | | | | | | | | | Previously we were leaking[*] memory in that the memory footprint of a "notmuch dump" run would continue to grow until the output was complete, and then finally all the memory would be freed. Now, the memory footprint is small and constant, O(1) rather than O(n) in the number of messages. [*] Not leaking in a valgrind sense---every byte was still carefully being accounted for and freed eventually.
* Add destroy functions for results, message, and tags.Gravatar Carl Worth2009-10-20
| | | | | | | | | | | | None of these are strictly necessary, (everything was leak-free without them), but notmuch_message_destroy can actually be useful for when one query has many message results, but only one is needed to be live at a time. The destroy functions for results and tags are fairly gratuitous, as there's unlikely to be any benefit from calling them. But they're all easy to add, (all of these functions are just wrappers for talloc_free), and we do so for consistency and completeness.
* Rename our talloc destructor functions to _destructor.Gravatar Carl Worth2009-10-20
| | | | | I want to reserve the _destroy names for some public functions I'm about to add.
* Implement 'notmuch dump'.Gravatar Carl Worth2009-10-20
| | | | | | | | | | | | | | | | This is a fairly big milestone for notmuch. It's our first command to do anything besides building the index, so it proves we can actually read valid results out from the index. It also puts in place almost all of the API and infrastructure we will need to allow searching of the database. Finally, with this change we are now using talloc inside of notmuch which is truly a delight to use. And now that I figured out how to use C++ objects with talloc allocation, (it requires grotty parts of C++ such as "placement new" and "explicit destructors"), we are valgrind-clean for "notmuch dump", (as in "no leaks are possible").
* Rename private notmuch_message_t to notmuch_message_file_tGravatar Carl Worth2009-10-20
| | | | | | | | | This is in preparation for a new, public notmuch_message_t. Eventually, the public notmuch_message_t is going to grow enough features to need to be file-backed and will likely need everything that's now in message-file.c. So we may fold these back into one object/implementation in the future.
* Makefile: Add automatic dependency tracking to the Makefile.Gravatar Carl Worth2009-10-20
| | | | With this, I really don't miss anything from automake.
* notmuch: Fix setup so that accepting the default mail path works.Gravatar Carl Worth2009-10-20
| | | | | | The recent change from GIOChannel to getline, (with a semantic change of the newline terminator now being included in the result that setup_command sees), broke this.
* message: Use g_hash_table_destroy instead of g_hash_table_unrefGravatar Carl Worth2009-10-20
| | | | | | | | | I'm trying to chase down 3 still-reachable pointers to glib hash tables. This change didn't help with that, but I think destroy might be a better semantic match for what I actually want. (It shouldn't matter though since I never take any additional references.)
* add_message: Fix memory leak of thread_ids GPtrArray.Gravatar Carl Worth2009-10-20
| | | | | | | | | We were properly feeing this memory when the thread-ids list was not empty, but leaking it when it was. Thanks, of course, to valgrind along with the G_SLICE=always-malloc environment variable which makes leak checking with glib almost bearable.
* database.cc: Document better pieces of glib that we're using.Gravatar Carl Worth2009-10-20
|
* message.c: Free leaked memory in notmuch_message objectGravatar Carl Worth2009-10-20
| | | | | | We were careful to free this memory when we finished parsing the headers, but we missed it for the case of closing the message without ever parsing all of the headers.
* notmuch: Use GNU libc getline() instead of glib GIOChannelGravatar Carl Worth2009-10-20
| | | | | Less reliance on glib is always nice for our memory-leak testing efforts.
* notmuch_database_open: Fix error message for file-not-found.Gravatar Carl Worth2009-10-20
| | | | | | | | | I was incorrectly using the return value of stat (-1) instead of errno (ENOENT) to try to construct the error message here. Also, while we're here, reword the error message to not have "stat" in it, which in spite of what a Unix programmer will tell you, is not actually a word.
* Add some explanation about NOTMUCH_BASE to setup_command.Gravatar Carl Worth2009-10-20
| | | | | | | Since we allow the user to enter a custom directory, we need to let the user know how to make this persistent. Of course, a better answer would be to take what the user entered and shove it into a ~/.notmuch-config file or so, but for now this will have to do.
* notmuch_database_create/open: Fix to handle NULL as documented.Gravatar Carl Worth2009-10-20
| | | | | | | | | | | When documenting these functions I described support for a NOTMUCH_BASE environment variable to be consulted in the case of a NULL path. Only, I had forgotten to actually write the code. This code exists now, with a new, exported function: notmuch_database_default_path
* notmuch_message_get_header: Fix bogus return of NULL header.Gravatar Carl Worth2009-10-20
| | | | | | | | | | | | | A simple bug meant that the correct value was being inserted into the hash table, but a NULL value would be returned in some cases. (If the value was already in the hash table at the beginning of the call the the correct value would be returned, but if the function had to parse to reach it then it would return NULL.) This was tripping up the recently-added code to ignore messages with NULL From:, Subject:, and To: headers, (which is fortunate since otherwise the broken parsing might have stayed hidden for longer).
* notmuch: Revamp help message a bit.Gravatar Carl Worth2009-10-19
| | | | | | The big update here is the addition of the dump and restore commands which are next on my list. Also, I've now come up with a syntax for documenting the arguments of sub-commands.
* notmuch: Ignore files that don't look like email messages.Gravatar Carl Worth2009-10-19
| | | | | | | This is helpful for things like indexes that other mail programs may have left around. It also means we can make the initial instructions much easier, (the user need not worry about moving away auxiliary files from some other email program).