mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-21 18:38:08 +01:00
CLI+lib: detect missing database in split configurations.
Eventually we want to do all opening of databases in the top level (main function). This means that detection of missing databases needs to move out of subcommands. It also requires updating the library to use the new NO_DATABASE status code.
This commit is contained in:
parent
2e39ce6eb5
commit
217f819608
4 changed files with 54 additions and 40 deletions
24
lib/open.cc
24
lib/open.cc
|
@ -209,8 +209,8 @@ _choose_database_path (void *ctx,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*database_path == NULL) {
|
if (*database_path == NULL) {
|
||||||
*message = strdup ("Error: Cannot open a database for a NULL path.\n");
|
*message = strdup ("Error: could not locate database.\n");
|
||||||
return NOTMUCH_STATUS_NULL_POINTER;
|
return NOTMUCH_STATUS_NO_DATABASE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*database_path[0] != '/') {
|
if (*database_path[0] != '/') {
|
||||||
|
@ -750,12 +750,12 @@ _maybe_load_config_from_database (notmuch_database_t *notmuch,
|
||||||
char *message; /* ignored */
|
char *message; /* ignored */
|
||||||
|
|
||||||
if (_db_dir_exists (database_path, &message))
|
if (_db_dir_exists (database_path, &message))
|
||||||
return NOTMUCH_STATUS_SUCCESS;
|
return NOTMUCH_STATUS_NO_DATABASE;
|
||||||
|
|
||||||
_set_database_path (notmuch, database_path);
|
_set_database_path (notmuch, database_path);
|
||||||
|
|
||||||
if (_notmuch_choose_xapian_path (notmuch, database_path, ¬much->xapian_path, &message))
|
if (_notmuch_choose_xapian_path (notmuch, database_path, ¬much->xapian_path, &message))
|
||||||
return NOTMUCH_STATUS_SUCCESS;
|
return NOTMUCH_STATUS_NO_DATABASE;
|
||||||
|
|
||||||
(void) _finish_open (notmuch, profile, NOTMUCH_DATABASE_MODE_READ_ONLY, key_file, &message);
|
(void) _finish_open (notmuch, profile, NOTMUCH_DATABASE_MODE_READ_ONLY, key_file, &message);
|
||||||
|
|
||||||
|
@ -798,19 +798,27 @@ notmuch_database_load_config (const char *database_path,
|
||||||
status = _choose_database_path (local, profile, key_file,
|
status = _choose_database_path (local, profile, key_file,
|
||||||
&database_path, &split, &message);
|
&database_path, &split, &message);
|
||||||
switch (status) {
|
switch (status) {
|
||||||
/* weirdly NULL_POINTER is what is returned if we fail to find
|
case NOTMUCH_STATUS_NO_DATABASE:
|
||||||
* a database */
|
|
||||||
case NOTMUCH_STATUS_NULL_POINTER:
|
|
||||||
case NOTMUCH_STATUS_SUCCESS:
|
case NOTMUCH_STATUS_SUCCESS:
|
||||||
|
if (! warning)
|
||||||
|
warning = status;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
goto DONE;
|
goto DONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (database_path) {
|
if (database_path) {
|
||||||
status = _maybe_load_config_from_database (notmuch, key_file, database_path, profile);
|
status = _maybe_load_config_from_database (notmuch, key_file, database_path, profile);
|
||||||
if (status)
|
switch (status) {
|
||||||
|
case NOTMUCH_STATUS_NO_DATABASE:
|
||||||
|
case NOTMUCH_STATUS_SUCCESS:
|
||||||
|
if (! warning)
|
||||||
|
warning = status;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
goto DONE;
|
goto DONE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key_file) {
|
if (key_file) {
|
||||||
|
|
47
notmuch.c
47
notmuch.c
|
@ -380,34 +380,12 @@ notmuch_command (notmuch_config_t *config,
|
||||||
notmuch_database_t *notmuch,
|
notmuch_database_t *notmuch,
|
||||||
unused(int argc), unused(char **argv))
|
unused(int argc), unused(char **argv))
|
||||||
{
|
{
|
||||||
char *db_path;
|
|
||||||
struct stat st;
|
|
||||||
|
|
||||||
/* If the user has never configured notmuch, then run
|
/* If the user has never configured notmuch, then run
|
||||||
* notmuch_setup_command which will give a nice welcome message,
|
* notmuch_setup_command which will give a nice welcome message,
|
||||||
* and interactively guide the user through the configuration. */
|
* and interactively guide the user through the configuration. */
|
||||||
if (notmuch_config_is_new (config))
|
if (notmuch_config_is_new (config))
|
||||||
return notmuch_setup_command (config, notmuch, 0, NULL);
|
return notmuch_setup_command (config, notmuch, 0, NULL);
|
||||||
|
|
||||||
/* Notmuch is already configured, but is there a database? */
|
|
||||||
db_path = talloc_asprintf (config, "%s/%s",
|
|
||||||
notmuch_config_get (notmuch, NOTMUCH_CONFIG_DATABASE_PATH),
|
|
||||||
".notmuch");
|
|
||||||
if (stat (db_path, &st)) {
|
|
||||||
if (errno != ENOENT) {
|
|
||||||
fprintf (stderr, "Error looking for notmuch database at %s: %s\n",
|
|
||||||
db_path, strerror (errno));
|
|
||||||
return EXIT_FAILURE;
|
|
||||||
}
|
|
||||||
printf ("Notmuch is configured, but there's not yet a database at\n\n\t%s\n\n",
|
|
||||||
db_path);
|
|
||||||
printf ("You probably want to run \"notmuch new\" now to create that database.\n\n"
|
|
||||||
"Note that the first run of \"notmuch new\" can take a very long time\n"
|
|
||||||
"and that the resulting database will use roughly the same amount of\n"
|
|
||||||
"storage space as the email being indexed.\n\n");
|
|
||||||
return EXIT_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
printf ("Notmuch is configured and appears to have a database. Excellent!\n\n"
|
printf ("Notmuch is configured and appears to have a database. Excellent!\n\n"
|
||||||
"At this point you can start exploring the functionality of notmuch by\n"
|
"At this point you can start exploring the functionality of notmuch by\n"
|
||||||
"using commands such as:\n\n"
|
"using commands such as:\n\n"
|
||||||
|
@ -576,12 +554,27 @@ main (int argc, char *argv[])
|
||||||
fputs ("Try running 'notmuch setup' to create a configuration.", stderr);
|
fputs ("Try running 'notmuch setup' to create a configuration.", stderr);
|
||||||
goto DONE;
|
goto DONE;
|
||||||
}
|
}
|
||||||
|
switch (status) {
|
||||||
if (status && (status != NOTMUCH_STATUS_NO_CONFIG)) {
|
case NOTMUCH_STATUS_NO_CONFIG:
|
||||||
if (status_string) {
|
if (! (command->mode & NOTMUCH_COMMAND_CONFIG_CREATE)) {
|
||||||
fputs (status_string, stderr);
|
fputs ("Try running 'notmuch setup' to create a configuration.", stderr);
|
||||||
free (status_string);
|
goto DONE;
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case NOTMUCH_STATUS_NO_DATABASE:
|
||||||
|
if (! command_name) {
|
||||||
|
printf ("Notmuch is configured, but no database was found.\n");
|
||||||
|
printf ("You probably want to run \"notmuch new\" now to create a database.\n\n"
|
||||||
|
"Note that the first run of \"notmuch new\" can take a very long time\n"
|
||||||
|
"and that the resulting database will use roughly the same amount of\n"
|
||||||
|
"storage space as the email being indexed.\n\n");
|
||||||
|
status = NOTMUCH_STATUS_SUCCESS;
|
||||||
|
goto DONE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case NOTMUCH_STATUS_SUCCESS:
|
||||||
|
break;
|
||||||
|
default:
|
||||||
goto DONE;
|
goto DONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,11 +26,8 @@ test_expect_equal_file ${expected_dir}/config-with-comments new-notmuch-config
|
||||||
test_begin_subtest "notmuch with a config but without a database suggests notmuch new"
|
test_begin_subtest "notmuch with a config but without a database suggests notmuch new"
|
||||||
notmuch 2>&1 | notmuch_dir_sanitize > OUTPUT
|
notmuch 2>&1 | notmuch_dir_sanitize > OUTPUT
|
||||||
cat <<EOF > EXPECTED
|
cat <<EOF > EXPECTED
|
||||||
Notmuch is configured, but there's not yet a database at
|
Notmuch is configured, but no database was found.
|
||||||
|
You probably want to run "notmuch new" now to create a database.
|
||||||
MAIL_DIR/.notmuch
|
|
||||||
|
|
||||||
You probably want to run "notmuch new" now to create that database.
|
|
||||||
|
|
||||||
Note that the first run of "notmuch new" can take a very long time
|
Note that the first run of "notmuch new" can take a very long time
|
||||||
and that the resulting database will use roughly the same amount of
|
and that the resulting database will use roughly the same amount of
|
||||||
|
|
|
@ -199,6 +199,22 @@ EOF
|
||||||
"$output" \
|
"$output" \
|
||||||
"Welcome to a new version of notmuch! Your database will now be upgraded."
|
"Welcome to a new version of notmuch! Your database will now be upgraded."
|
||||||
|
|
||||||
|
test_begin_subtest "notmuch +config -database suggests notmuch new ($config)"
|
||||||
|
mv "$XAPIAN_PATH" "${XAPIAN_PATH}.bak"
|
||||||
|
notmuch > OUTPUT
|
||||||
|
cat <<EOF > EXPECTED
|
||||||
|
Notmuch is configured, but no database was found.
|
||||||
|
You probably want to run "notmuch new" now to create a database.
|
||||||
|
|
||||||
|
Note that the first run of "notmuch new" can take a very long time
|
||||||
|
and that the resulting database will use roughly the same amount of
|
||||||
|
storage space as the email being indexed.
|
||||||
|
|
||||||
|
EOF
|
||||||
|
mv "${XAPIAN_PATH}.bak" "$XAPIAN_PATH"
|
||||||
|
|
||||||
|
test_expect_equal_file EXPECTED OUTPUT
|
||||||
|
|
||||||
restore_config
|
restore_config
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue