This documentation is for Dovecot v1.x, see wiki2 for v2.x documentation.

Mail Index API

lib-index/mail-index.h contains the functions to access the index files. mail-cache.h contains the functions to access the cache file.

The purpose of the main structures are:

Views and maps

In general you access all the data in the index files via views. The mails are accessed using sequence numbers, which change only when the view is synchronized.

For accessing messages with their UIDs, you'll first need to convert them to sequences with either mail_index_lookup_uid() or mail_index_lookup_uid_range().

mail_index_lookup() can be used to look up a single record's UID and flags. The returned record points to the latest map, so that it contains the latest flag changes. If the message was already expunged from the latest map, it returns 0.

mail_index_lookup_full() can be used to get also the map where the message was found. This can be important with extensions. If extension record's state depends on the extension header, they must be looked up from the same map. For this reason there exists mail_index_map_get_header_ext() and mail_index_lookup_ext_full() functions which take the map as parameter. The non-map versions return the data from the latest map if the message hasn't been expunged.

None: Design/Indexes/MailIndexApi (last edited 2009-03-15 22:35:21 by localhost)