mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-21 18:38:08 +01:00
247 lines
7.9 KiB
C
247 lines
7.9 KiB
C
/* notmuch - Not much of an email program, (just index and search)
|
|
*
|
|
* Copyright © 2009 Carl Worth
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see https://www.gnu.org/licenses/ .
|
|
*
|
|
* Author: Carl Worth <cworth@cworth.org>
|
|
*/
|
|
|
|
#include "notmuch-client.h"
|
|
|
|
static const char *
|
|
make_path_absolute (void *ctx, const char *path)
|
|
{
|
|
char *cwd;
|
|
|
|
if (*path == '/')
|
|
return path;
|
|
|
|
cwd = getcwd (NULL, 0);
|
|
if (cwd == NULL) {
|
|
fprintf (stderr, "Out of memory.\n");
|
|
return NULL;
|
|
}
|
|
|
|
path = talloc_asprintf (ctx, "%s/%s", cwd, path);
|
|
if (path == NULL)
|
|
fprintf (stderr, "Out of memory.\n");
|
|
|
|
free (cwd);
|
|
|
|
return path;
|
|
}
|
|
|
|
static void
|
|
welcome_message_pre_setup (void)
|
|
{
|
|
printf (
|
|
"Welcome to notmuch!\n\n"
|
|
|
|
"The goal of notmuch is to help you manage and search your collection of\n"
|
|
"email, and to efficiently keep up with the flow of email as it comes in.\n\n"
|
|
|
|
"Notmuch needs to know a few things about you such as your name and email\n"
|
|
"address, as well as the directory that contains your email. This is where\n"
|
|
"you already have mail stored and where messages will be delivered in the\n"
|
|
"future. This directory can contain any number of sub-directories. Regular\n"
|
|
"files in these directories should be individual email messages. If there\n"
|
|
"are other, non-email files (such as indexes maintained by other email\n"
|
|
"programs) then notmuch will do its best to detect those and ignore them.\n\n"
|
|
|
|
"If you already have your email being delivered to directories in either\n"
|
|
"maildir or mh format, then that's perfect. Mail storage that uses mbox\n"
|
|
"format, (where one mbox file contains many messages), will not work with\n"
|
|
"notmuch. If that's how your mail is currently stored, we recommend you\n"
|
|
"first convert it to maildir format with a utility such as mb2md. You can\n"
|
|
"continue configuring notmuch now, but be sure to complete the conversion\n"
|
|
"before you run \"notmuch new\" for the first time.\n\n");
|
|
}
|
|
|
|
static void
|
|
welcome_message_post_setup (void)
|
|
{
|
|
printf ("\n"
|
|
"Notmuch is now configured, and the configuration settings are saved in\n"
|
|
"a file in your home directory named .notmuch-config. If you'd like to\n"
|
|
"change the configuration in the future, you can either edit that file\n"
|
|
"directly or run \"notmuch setup\". To choose an alternate configuration\n"
|
|
"location, set ${NOTMUCH_CONFIG}.\n\n"
|
|
|
|
"The next step is to run \"notmuch new\" which will create a database\n"
|
|
"that indexes all of your mail. Depending on the amount of mail you have\n"
|
|
"the initial indexing process can take a long time, so expect that.\n"
|
|
"Also, the resulting database will require roughly the same amount of\n"
|
|
"storage space as your current collection of email. So please ensure you\n"
|
|
"have sufficient storage space available now.\n\n");
|
|
}
|
|
|
|
static void
|
|
print_tag_list (notmuch_config_values_t *tags)
|
|
{
|
|
bool first = false;
|
|
|
|
for (;
|
|
notmuch_config_values_valid (tags);
|
|
notmuch_config_values_move_to_next (tags)) {
|
|
if (! first)
|
|
printf (" ");
|
|
first = false;
|
|
printf ("%s", notmuch_config_values_get (tags));
|
|
}
|
|
}
|
|
|
|
static GPtrArray *
|
|
parse_tag_list (void *ctx, char *response)
|
|
{
|
|
GPtrArray *tags = g_ptr_array_new ();
|
|
char *tag = response;
|
|
char *space;
|
|
|
|
while (tag && *tag) {
|
|
space = strchr (tag, ' ');
|
|
if (space)
|
|
g_ptr_array_add (tags, talloc_strndup (ctx, tag, space - tag));
|
|
else
|
|
g_ptr_array_add (tags, talloc_strdup (ctx, tag));
|
|
tag = space;
|
|
while (tag && *tag == ' ')
|
|
tag++;
|
|
}
|
|
|
|
return tags;
|
|
}
|
|
|
|
int
|
|
notmuch_setup_command (notmuch_database_t *notmuch,
|
|
int argc, char *argv[])
|
|
{
|
|
char *response = NULL;
|
|
size_t response_size = 0;
|
|
GPtrArray *other_emails;
|
|
notmuch_config_values_t *new_tags, *search_exclude_tags, *emails;
|
|
notmuch_conffile_t *config;
|
|
|
|
#define prompt(format, ...) \
|
|
do { \
|
|
printf (format, ##__VA_ARGS__); \
|
|
fflush (stdout); \
|
|
if (getline (&response, &response_size, stdin) < 0) { \
|
|
printf ("Exiting.\n"); \
|
|
exit (EXIT_FAILURE); \
|
|
} \
|
|
chomp_newline (response); \
|
|
} while (0)
|
|
|
|
if (notmuch_minimal_options ("setup", argc, argv) < 0)
|
|
return EXIT_FAILURE;
|
|
|
|
if (notmuch_requested_db_uuid)
|
|
fprintf (stderr, "Warning: ignoring --uuid=%s\n",
|
|
notmuch_requested_db_uuid);
|
|
|
|
config = notmuch_conffile_open (notmuch,
|
|
notmuch_config_path (notmuch), true);
|
|
if (! config)
|
|
return EXIT_FAILURE;
|
|
|
|
if (notmuch_conffile_is_new (config))
|
|
welcome_message_pre_setup ();
|
|
|
|
prompt ("Your full name [%s]: ", notmuch_config_get (notmuch, NOTMUCH_CONFIG_USER_NAME));
|
|
if (strlen (response))
|
|
notmuch_conffile_set_user_name (config, response);
|
|
|
|
prompt ("Your primary email address [%s]: ",
|
|
notmuch_config_get (notmuch, NOTMUCH_CONFIG_PRIMARY_EMAIL));
|
|
if (strlen (response))
|
|
notmuch_conffile_set_user_primary_email (config, response);
|
|
|
|
other_emails = g_ptr_array_new ();
|
|
|
|
for (emails = notmuch_config_get_values (notmuch, NOTMUCH_CONFIG_OTHER_EMAIL);
|
|
notmuch_config_values_valid (emails);
|
|
notmuch_config_values_move_to_next (emails)) {
|
|
const char *email = notmuch_config_values_get (emails);
|
|
|
|
prompt ("Additional email address [%s]: ", email);
|
|
if (strlen (response))
|
|
g_ptr_array_add (other_emails, talloc_strdup (config, response));
|
|
else
|
|
g_ptr_array_add (other_emails, talloc_strdup (config, email));
|
|
}
|
|
|
|
do {
|
|
prompt ("Additional email address [Press 'Enter' if none]: ");
|
|
if (strlen (response))
|
|
g_ptr_array_add (other_emails, talloc_strdup (config, response));
|
|
} while (strlen (response));
|
|
if (other_emails->len)
|
|
notmuch_conffile_set_user_other_email (config,
|
|
(const char **)
|
|
other_emails->pdata,
|
|
other_emails->len);
|
|
g_ptr_array_free (other_emails, true);
|
|
|
|
prompt ("Top-level directory of your email archive [%s]: ",
|
|
notmuch_config_get (notmuch, NOTMUCH_CONFIG_DATABASE_PATH));
|
|
if (strlen (response)) {
|
|
const char *absolute_path;
|
|
|
|
absolute_path = make_path_absolute (config, response);
|
|
notmuch_conffile_set_database_path (config, absolute_path);
|
|
}
|
|
|
|
new_tags = notmuch_config_get_values (notmuch, NOTMUCH_CONFIG_NEW_TAGS);
|
|
|
|
printf ("Tags to apply to all new messages (separated by spaces) [");
|
|
print_tag_list (new_tags);
|
|
prompt ("]: ");
|
|
|
|
if (strlen (response)) {
|
|
GPtrArray *tags = parse_tag_list (config, response);
|
|
|
|
notmuch_conffile_set_new_tags (config, (const char **) tags->pdata,
|
|
tags->len);
|
|
|
|
g_ptr_array_free (tags, true);
|
|
}
|
|
|
|
search_exclude_tags = notmuch_config_get_values (notmuch, NOTMUCH_CONFIG_EXCLUDE_TAGS);
|
|
|
|
printf ("Tags to exclude when searching messages (separated by spaces) [");
|
|
print_tag_list (search_exclude_tags);
|
|
prompt ("]: ");
|
|
|
|
if (strlen (response)) {
|
|
GPtrArray *tags = parse_tag_list (config, response);
|
|
|
|
notmuch_conffile_set_search_exclude_tags (config,
|
|
(const char **) tags->pdata,
|
|
tags->len);
|
|
|
|
g_ptr_array_free (tags, true);
|
|
}
|
|
|
|
if (notmuch_conffile_save (config))
|
|
return EXIT_FAILURE;
|
|
|
|
if (config)
|
|
notmuch_conffile_close (config);
|
|
|
|
if (notmuch_conffile_is_new (config))
|
|
welcome_message_post_setup ();
|
|
|
|
return EXIT_SUCCESS;
|
|
}
|