mirror of
https://git.notmuchmail.org/git/notmuch
synced 2025-01-08 17:51:42 +01:00
notmuch new/tag: Flush all changes to database when interrupted.
By installing a signal handler for SIGINT we can ensure that no work that is already complete will be lost if the user interrupts a "notmuch new" run with Control-C.
This commit is contained in:
parent
8561c7463a
commit
f4245aec94
2 changed files with 52 additions and 18 deletions
|
@ -28,6 +28,16 @@ handle_sigalrm (unused (int signal))
|
||||||
do_add_files_print_progress = 1;
|
do_add_files_print_progress = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static volatile sig_atomic_t interrupted;
|
||||||
|
|
||||||
|
static void
|
||||||
|
handle_sigint (unused (int sig))
|
||||||
|
{
|
||||||
|
static char msg[] = "Stopping... \n";
|
||||||
|
write(2, msg, sizeof(msg)-1);
|
||||||
|
interrupted = 1;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tag_inbox_and_unread (notmuch_message_t *message)
|
tag_inbox_and_unread (notmuch_message_t *message)
|
||||||
{
|
{
|
||||||
|
@ -125,7 +135,7 @@ add_files_recursive (notmuch_database_t *notmuch,
|
||||||
pathconf (path, _PC_NAME_MAX) + 1;
|
pathconf (path, _PC_NAME_MAX) + 1;
|
||||||
entry = malloc (entry_length);
|
entry = malloc (entry_length);
|
||||||
|
|
||||||
while (1) {
|
while (!interrupted) {
|
||||||
err = readdir_r (dir, entry, &e);
|
err = readdir_r (dir, entry, &e);
|
||||||
if (err) {
|
if (err) {
|
||||||
fprintf (stderr, "Error reading directory: %s\n",
|
fprintf (stderr, "Error reading directory: %s\n",
|
||||||
|
@ -319,7 +329,7 @@ count_files (const char *path, int *count)
|
||||||
pathconf (path, _PC_NAME_MAX) + 1;
|
pathconf (path, _PC_NAME_MAX) + 1;
|
||||||
entry = malloc (entry_length);
|
entry = malloc (entry_length);
|
||||||
|
|
||||||
while (1) {
|
while (!interrupted) {
|
||||||
err = readdir_r (dir, entry, &e);
|
err = readdir_r (dir, entry, &e);
|
||||||
if (err) {
|
if (err) {
|
||||||
fprintf (stderr, "Error reading directory: %s\n",
|
fprintf (stderr, "Error reading directory: %s\n",
|
||||||
|
@ -385,7 +395,14 @@ notmuch_new_command (void *ctx,
|
||||||
struct stat st;
|
struct stat st;
|
||||||
const char *db_path;
|
const char *db_path;
|
||||||
char *dot_notmuch_path;
|
char *dot_notmuch_path;
|
||||||
int new_database = 0;
|
struct sigaction action;
|
||||||
|
|
||||||
|
/* Setup our handler for SIGINT */
|
||||||
|
memset (&action, 0, sizeof (struct sigaction));
|
||||||
|
action.sa_handler = handle_sigint;
|
||||||
|
sigemptyset (&action.sa_mask);
|
||||||
|
action.sa_flags = SA_RESTART;
|
||||||
|
sigaction (SIGINT, &action, NULL);
|
||||||
|
|
||||||
config = notmuch_config_open (ctx, NULL, NULL);
|
config = notmuch_config_open (ctx, NULL, NULL);
|
||||||
if (config == NULL)
|
if (config == NULL)
|
||||||
|
@ -396,10 +413,20 @@ notmuch_new_command (void *ctx,
|
||||||
dot_notmuch_path = talloc_asprintf (ctx, "%s/%s", db_path, ".notmuch");
|
dot_notmuch_path = talloc_asprintf (ctx, "%s/%s", db_path, ".notmuch");
|
||||||
|
|
||||||
if (stat (dot_notmuch_path, &st)) {
|
if (stat (dot_notmuch_path, &st)) {
|
||||||
new_database = 1;
|
int count;
|
||||||
|
|
||||||
|
count = 0;
|
||||||
|
count_files (db_path, &count);
|
||||||
|
if (interrupted)
|
||||||
|
return 1;
|
||||||
|
|
||||||
notmuch = notmuch_database_create (db_path);
|
notmuch = notmuch_database_create (db_path);
|
||||||
|
add_files_state.ignore_read_only_directories = FALSE;
|
||||||
|
add_files_state.total_files = count;
|
||||||
} else {
|
} else {
|
||||||
notmuch = notmuch_database_open (db_path);
|
notmuch = notmuch_database_open (db_path);
|
||||||
|
add_files_state.ignore_read_only_directories = TRUE;
|
||||||
|
add_files_state.total_files = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (notmuch == NULL)
|
if (notmuch == NULL)
|
||||||
|
@ -408,17 +435,6 @@ notmuch_new_command (void *ctx,
|
||||||
talloc_free (dot_notmuch_path);
|
talloc_free (dot_notmuch_path);
|
||||||
dot_notmuch_path = NULL;
|
dot_notmuch_path = NULL;
|
||||||
|
|
||||||
if (new_database) {
|
|
||||||
int count;
|
|
||||||
count = 0;
|
|
||||||
count_files (db_path, &count);
|
|
||||||
add_files_state.ignore_read_only_directories = FALSE;
|
|
||||||
add_files_state.total_files = count;
|
|
||||||
} else {
|
|
||||||
add_files_state.ignore_read_only_directories = TRUE;
|
|
||||||
add_files_state.total_files = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
add_files_state.saw_read_only_directory = FALSE;
|
add_files_state.saw_read_only_directory = FALSE;
|
||||||
add_files_state.total_files = 0;
|
add_files_state.total_files = 0;
|
||||||
add_files_state.processed_files = 0;
|
add_files_state.processed_files = 0;
|
||||||
|
@ -465,5 +481,5 @@ notmuch_new_command (void *ctx,
|
||||||
|
|
||||||
notmuch_database_close (notmuch);
|
notmuch_database_close (notmuch);
|
||||||
|
|
||||||
return ret;
|
return ret || interrupted;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,16 @@
|
||||||
|
|
||||||
#include "notmuch-client.h"
|
#include "notmuch-client.h"
|
||||||
|
|
||||||
|
static volatile sig_atomic_t interrupted;
|
||||||
|
|
||||||
|
static void
|
||||||
|
handle_sigint (unused (int sig))
|
||||||
|
{
|
||||||
|
static char msg[] = "Stopping... \n";
|
||||||
|
write(2, msg, sizeof(msg)-1);
|
||||||
|
interrupted = 1;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
notmuch_tag_command (void *ctx, unused (int argc), unused (char *argv[]))
|
notmuch_tag_command (void *ctx, unused (int argc), unused (char *argv[]))
|
||||||
{
|
{
|
||||||
|
@ -32,8 +42,16 @@ notmuch_tag_command (void *ctx, unused (int argc), unused (char *argv[]))
|
||||||
notmuch_query_t *query;
|
notmuch_query_t *query;
|
||||||
notmuch_messages_t *messages;
|
notmuch_messages_t *messages;
|
||||||
notmuch_message_t *message;
|
notmuch_message_t *message;
|
||||||
|
struct sigaction action;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* Setup our handler for SIGINT */
|
||||||
|
memset (&action, 0, sizeof (struct sigaction));
|
||||||
|
action.sa_handler = handle_sigint;
|
||||||
|
sigemptyset (&action.sa_mask);
|
||||||
|
action.sa_flags = SA_RESTART;
|
||||||
|
sigaction (SIGINT, &action, NULL);
|
||||||
|
|
||||||
add_tags = talloc_size (ctx, argc * sizeof (int));
|
add_tags = talloc_size (ctx, argc * sizeof (int));
|
||||||
if (add_tags == NULL) {
|
if (add_tags == NULL) {
|
||||||
fprintf (stderr, "Out of memory.\n");
|
fprintf (stderr, "Out of memory.\n");
|
||||||
|
@ -87,7 +105,7 @@ notmuch_tag_command (void *ctx, unused (int argc), unused (char *argv[]))
|
||||||
}
|
}
|
||||||
|
|
||||||
for (messages = notmuch_query_search_messages (query, 0, -1);
|
for (messages = notmuch_query_search_messages (query, 0, -1);
|
||||||
notmuch_messages_has_more (messages);
|
notmuch_messages_has_more (messages) && !interrupted;
|
||||||
notmuch_messages_advance (messages))
|
notmuch_messages_advance (messages))
|
||||||
{
|
{
|
||||||
message = notmuch_messages_get (messages);
|
message = notmuch_messages_get (messages);
|
||||||
|
@ -109,5 +127,5 @@ notmuch_tag_command (void *ctx, unused (int argc), unused (char *argv[]))
|
||||||
notmuch_query_destroy (query);
|
notmuch_query_destroy (query);
|
||||||
notmuch_database_close (notmuch);
|
notmuch_database_close (notmuch);
|
||||||
|
|
||||||
return 0;
|
return interrupted;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue