mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-25 12:28:09 +01:00
Prototypes for directory tracking
There's no functionality here yet---just a sketch of what the interface could look like.
This commit is contained in:
parent
f11aaa3678
commit
95deec1b27
1 changed files with 45 additions and 42 deletions
|
@ -114,6 +114,8 @@ typedef struct _notmuch_thread notmuch_thread_t;
|
||||||
typedef struct _notmuch_messages notmuch_messages_t;
|
typedef struct _notmuch_messages notmuch_messages_t;
|
||||||
typedef struct _notmuch_message notmuch_message_t;
|
typedef struct _notmuch_message notmuch_message_t;
|
||||||
typedef struct _notmuch_tags notmuch_tags_t;
|
typedef struct _notmuch_tags notmuch_tags_t;
|
||||||
|
typedef struct _notmuch_directory notmuch_directory_t;
|
||||||
|
typedef struct _notmuch_files notmuch_files_t;
|
||||||
|
|
||||||
/* Create a new, empty notmuch database located at 'path'.
|
/* Create a new, empty notmuch database located at 'path'.
|
||||||
*
|
*
|
||||||
|
@ -178,56 +180,47 @@ notmuch_database_close (notmuch_database_t *database);
|
||||||
const char *
|
const char *
|
||||||
notmuch_database_get_path (notmuch_database_t *database);
|
notmuch_database_get_path (notmuch_database_t *database);
|
||||||
|
|
||||||
/* Store an mtime within the database for 'path'.
|
/* Read the stored contents of a directory from the database.
|
||||||
*
|
*
|
||||||
* Here,'path' should be the path of a directory relative to the path
|
* Here, 'dirname' should be a path relative to the path of
|
||||||
* of 'database' (see notmuch_database_get_path), or else should be an
|
* 'database' (see notmuch_database_get_path), or else should be an
|
||||||
* absolute path with initial components that match the path of
|
* absolute filename with initial components that match the path of
|
||||||
* 'database'.
|
* 'database'.
|
||||||
*
|
*
|
||||||
* The intention is for the caller to use the mtime to allow efficient
|
* The stored mtime of the directory along with a list of messages
|
||||||
* identification of new messages to be added to the database. The
|
* and directories in the database contained in 'dirname' are
|
||||||
* recommended usage is as follows:
|
* returned in 'directory'. The entries are sorted by filename.
|
||||||
*
|
|
||||||
* o Read the mtime of a directory from the filesystem
|
|
||||||
*
|
|
||||||
* o Call add_message for all mail files in the directory
|
|
||||||
*
|
|
||||||
* o Call notmuch_database_set_directory_mtime
|
|
||||||
*
|
|
||||||
* Then, when wanting to check for updates to the directory in the
|
|
||||||
* future, the client can call notmuch_database_get_directory_mtime
|
|
||||||
* and know that it only needs to add files if the mtime of the
|
|
||||||
* directory and files are newer than the stored timestamp.
|
|
||||||
*
|
|
||||||
* Note: The notmuch_database_get_directory_mtime function does not
|
|
||||||
* allow the caller to distinguish a timestamp of 0 from a
|
|
||||||
* non-existent timestamp. So don't store a timestamp of 0 unless you
|
|
||||||
* are comfortable with that.
|
|
||||||
*
|
|
||||||
* Return value:
|
|
||||||
*
|
|
||||||
* NOTMUCH_STATUS_SUCCESS: mtime successfully stored in database.
|
|
||||||
*
|
|
||||||
* NOTMUCH_STATUS_XAPIAN_EXCEPTION: A Xapian exception
|
|
||||||
* occurred, mtime not stored.
|
|
||||||
*/
|
*/
|
||||||
notmuch_status_t
|
notmuch_status_t
|
||||||
notmuch_database_set_directory_mtime (notmuch_database_t *database,
|
notmuch_database_read_directory (notmuch_database_t *database,
|
||||||
const char *path,
|
const char *filename,
|
||||||
time_t mtime);
|
notmuch_directory_t **directory);
|
||||||
|
|
||||||
/* Retrieve the mtime from the database for 'path'.
|
/* Return the recorded 'mtime' for the given directory
|
||||||
*
|
|
||||||
* Returns the mtime value previously stored by calling
|
|
||||||
* notmuch_database_set_directory_mtime with the same 'path'.
|
|
||||||
*
|
|
||||||
* Returns 0 if no mtime is stored for 'path' or if any error occurred
|
|
||||||
* querying the database.
|
|
||||||
*/
|
*/
|
||||||
time_t
|
time_t
|
||||||
notmuch_database_get_directory_mtime (notmuch_database_t *database,
|
notmuch_directory_get_mtime (notmuch_directory_t *directory);
|
||||||
const char *path);
|
|
||||||
|
/* Return a notmuch_files_t iterator for all regular files in 'directory'.
|
||||||
|
*/
|
||||||
|
notmuch_files_t *
|
||||||
|
notmuch_directory_get_files (notmuch_directory_t *directory);
|
||||||
|
|
||||||
|
/* Return a notmuch_files_t iterator for all sub-directories of
|
||||||
|
* 'directory'.
|
||||||
|
*/
|
||||||
|
notmuch_files_t *
|
||||||
|
notmuch_directory_get_subdirs (notmuch_directory_t *directory);
|
||||||
|
|
||||||
|
/* Does the given notmuch_files_t object contain any more results.
|
||||||
|
*/
|
||||||
|
notmuch_bool_t
|
||||||
|
notmuch_files_has_more (notmuch_files_t *files);
|
||||||
|
|
||||||
|
/* Get the current filename from 'files' as a string.
|
||||||
|
*/
|
||||||
|
const char *
|
||||||
|
notmuch_files_get_filename (notmuch_files_t *files);
|
||||||
|
|
||||||
/* Add a new message to the given notmuch database.
|
/* Add a new message to the given notmuch database.
|
||||||
*
|
*
|
||||||
|
@ -728,6 +721,16 @@ notmuch_message_get_replies (notmuch_message_t *message);
|
||||||
const char *
|
const char *
|
||||||
notmuch_message_get_filename (notmuch_message_t *message);
|
notmuch_message_get_filename (notmuch_message_t *message);
|
||||||
|
|
||||||
|
/* Remove a filename for the email corresponding to 'message'.
|
||||||
|
*
|
||||||
|
* This removes the association between a filename and a message,
|
||||||
|
* when the last filename is gone, the entire message is removed
|
||||||
|
* from the database.
|
||||||
|
*/
|
||||||
|
notmuch_status_t
|
||||||
|
notmuch_message_remove_filename (notmuch_message_t *message,
|
||||||
|
const char *filename);
|
||||||
|
|
||||||
/* Message flags */
|
/* Message flags */
|
||||||
typedef enum _notmuch_message_flag {
|
typedef enum _notmuch_message_flag {
|
||||||
NOTMUCH_MESSAGE_FLAG_MATCH,
|
NOTMUCH_MESSAGE_FLAG_MATCH,
|
||||||
|
|
Loading…
Reference in a new issue