* implement 'mu view'
This commit is contained in:
4
TODO
4
TODO
@ -2,7 +2,7 @@
|
||||
|
||||
* Future release
|
||||
|
||||
** release 0.7 [81%]
|
||||
** release 0.7 [90%]
|
||||
|
||||
- [X] signal handler for indexing
|
||||
- [X] fix max 10000 matches limit
|
||||
@ -11,7 +11,7 @@
|
||||
- [X] make 'make distcheck' work
|
||||
- [ ] don't store both values and terms
|
||||
- [X] fix the batch stuff
|
||||
- [ ] mu view <path>
|
||||
- [X] mu view <path>
|
||||
- [X] basic test suite
|
||||
- [X] auto clean log file
|
||||
- [X] configure error for missing ->dt_dtype
|
||||
|
||||
48
man/mu.1
48
man/mu.1
@ -1,4 +1,4 @@
|
||||
.TH MU 1 "January 2010" "User Manuals"
|
||||
.TH MU 1 "February 2010" "User Manuals"
|
||||
|
||||
.SH NAME
|
||||
|
||||
@ -8,22 +8,26 @@ mu \- index and search e-mail messages stored in Maildirs
|
||||
|
||||
.B mu index [options]
|
||||
|
||||
.B mu find [options] <search expression>
|
||||
|
||||
.B mu mkdir [options] <dir> [<dirs>]
|
||||
|
||||
.B mu cleanup [options]
|
||||
|
||||
.B mu help [options]
|
||||
.B mu find [options] <search expression>
|
||||
|
||||
.B mu view <file> [<files>]
|
||||
|
||||
.B mu mkdir [options] <dir> [<dirs>]
|
||||
|
||||
.B mu [options]
|
||||
|
||||
.SH DESCRIPTION
|
||||
|
||||
\fBmu\fR is a set of tools for indexing and searching e-mail messages stored
|
||||
in Maildirs. It does so by scanning a Maildir directory tree and analyzing the
|
||||
e-mail messages found. The results of this analysis are stored in a database,
|
||||
which can then be queried.
|
||||
\fBmu\fR is a set of tools for dealing with e-mail messages in Maildirs.
|
||||
|
||||
Its main function is enable searching of e-mail messages. It does so by
|
||||
scanning a Maildir directory tree and analyzing the e-mail messages found. The
|
||||
results of this analysis are stored in a database, which can then be queried.
|
||||
|
||||
In addition to indexing and searching, \fBmu\fR also offers functionality for
|
||||
viewing messages and creating maildirs.
|
||||
|
||||
\fBmu\fR can be used from the command line, or can be integrated with e-mail
|
||||
clients. This manpage contains examples of both.
|
||||
@ -40,14 +44,18 @@ information in a database
|
||||
.TP
|
||||
\fBfind\fR
|
||||
for finding messages in your database, using certain search parameters (see
|
||||
below for details).
|
||||
below for details)
|
||||
|
||||
.TP
|
||||
\fBview\fR
|
||||
for displaying e-mail messages
|
||||
|
||||
.TP
|
||||
\fBmkdir\fR
|
||||
for creating Maildirs.
|
||||
for creating Maildirs
|
||||
|
||||
.TP
|
||||
The various commands are discussed in more detail below.
|
||||
The various commands are discussed in more detail below
|
||||
|
||||
.SH GENERAL OPTIONS
|
||||
|
||||
@ -217,7 +225,8 @@ but the author has not seen it getting under 30,0000 messages per second).
|
||||
|
||||
.SH THE CLEANUP COMMAND
|
||||
The \fBcleanup\fR command removes messages for which no corresponding file can
|
||||
be found, from the database.
|
||||
be found, from the database. Note that this is done automatically when running
|
||||
\fBmu index\fR (unless \fB\-\-nocleanup\fR was specified).
|
||||
|
||||
|
||||
.SH THE FIND COMMAND
|
||||
@ -469,12 +478,17 @@ typing 'Q' will start a query.
|
||||
(message "Query failed")))
|
||||
.fi
|
||||
|
||||
.SH THE VIEW COMMAND
|
||||
With the \fBview\fR command, you can view one or more e-mail messages as they
|
||||
are stored as files on disk. It does not require or use the Xapian database.
|
||||
|
||||
Currently, the command shows some common headers (From:, To:, Cc:, Subject:
|
||||
and Date:) and the plain-text body of the message.
|
||||
|
||||
.SH THE MKDIR COMMAND
|
||||
|
||||
With the
|
||||
.B mkdir
|
||||
command, you can create new Maildirs with permissions 0755. For example,
|
||||
With the \fBmkdir\fR command, you can create new Maildirs with permissions
|
||||
0755. For example,
|
||||
|
||||
.nf
|
||||
mu mkdir tom dick harry
|
||||
|
||||
@ -41,7 +41,7 @@
|
||||
static void
|
||||
update_warning (void)
|
||||
{
|
||||
g_warning ("the database needs to be updated to version %s",
|
||||
g_printerr ("the database needs to be updated to version %s\n",
|
||||
MU_XAPIAN_DB_VERSION);
|
||||
g_message ("please run 'mu index --empty' (see the manpage)");
|
||||
}
|
||||
@ -274,19 +274,19 @@ query_params_valid (MuConfigOptions *opts)
|
||||
{
|
||||
if (opts->linksdir)
|
||||
if (opts->xquery) {
|
||||
g_warning ("Invalid option for '--linksdir'");
|
||||
g_printerr ("Invalid option for '--linksdir'\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (!opts->params[0] || !opts->params[1]) {
|
||||
g_warning ("Missing search expression");
|
||||
g_printerr ("Missing search expression\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (mu_util_check_dir (opts->xpath, TRUE, FALSE))
|
||||
return TRUE;
|
||||
|
||||
g_warning ("%s is not a readable Xapian directory", opts->xpath);
|
||||
g_printerr ("%s is not a readable Xapian directory\n", opts->xpath);
|
||||
g_message ("Did you run 'mu index'?");
|
||||
|
||||
return FALSE;
|
||||
@ -305,8 +305,8 @@ mu_cmd_find (MuConfigOptions *opts)
|
||||
return FALSE;
|
||||
|
||||
if (mu_util_xapian_db_is_empty (opts->xpath)) {
|
||||
g_warning ("The database is empty; "
|
||||
"use 'mu index' to add some messages");
|
||||
g_printerr ("The database is empty; "
|
||||
"use 'mu index' to add some messages\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
@ -322,7 +322,7 @@ mu_cmd_find (MuConfigOptions *opts)
|
||||
|
||||
xapian = mu_query_xapian_new (opts->xpath);
|
||||
if (!xapian) {
|
||||
g_warning ("Failed to create Xapian query");
|
||||
g_printerr ("Failed to create a Xapian query\n");
|
||||
mu_msg_gmime_uninit ();
|
||||
return FALSE;
|
||||
}
|
||||
@ -335,13 +335,71 @@ mu_cmd_find (MuConfigOptions *opts)
|
||||
return rv;
|
||||
}
|
||||
|
||||
/* we ignore fields for now */
|
||||
static gboolean
|
||||
view_file (const gchar *path, const gchar *fields)
|
||||
{
|
||||
MuMsgGMime* msg;
|
||||
const char *field;
|
||||
time_t date;
|
||||
|
||||
msg = mu_msg_gmime_new (path);
|
||||
if (!msg)
|
||||
return FALSE;
|
||||
|
||||
field = mu_msg_gmime_get_from (msg);
|
||||
if (field)
|
||||
g_print ("From: %s\n", field);
|
||||
|
||||
field = mu_msg_gmime_get_to (msg);
|
||||
if (field)
|
||||
g_print ("To: %s\n", field);
|
||||
|
||||
field = mu_msg_gmime_get_cc (msg);
|
||||
if (field)
|
||||
g_print ("Cc: %s\n", field);
|
||||
|
||||
field = mu_msg_gmime_get_subject (msg);
|
||||
if (field)
|
||||
g_print ("Subject: %s\n", field);
|
||||
|
||||
date = mu_msg_gmime_get_date (msg);
|
||||
if (date)
|
||||
g_print ("Date: %s\n",
|
||||
mu_msg_str_date_s (date));
|
||||
|
||||
field = mu_msg_gmime_get_body_text (msg);
|
||||
if (field)
|
||||
g_print ("\n%s\n", field);
|
||||
else
|
||||
/* not really an error */
|
||||
g_warning ("No text body found for %s", path);
|
||||
|
||||
mu_msg_gmime_destroy (msg);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
gboolean
|
||||
mu_cmd_view (MuConfigOptions *opts)
|
||||
{
|
||||
g_return_val_if_fail (opts, FALSE);
|
||||
gboolean rv;
|
||||
int i;
|
||||
|
||||
return TRUE; /* FIXME */
|
||||
g_return_val_if_fail (opts, FALSE);
|
||||
|
||||
/* note: params[0] will be 'view' */
|
||||
if (!opts->params[0] || !opts->params[1]) {
|
||||
g_printerr ("Missing files to view\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
mu_msg_gmime_init();
|
||||
|
||||
rv = TRUE;
|
||||
for (i = 1; opts->params[i] && rv; ++i)
|
||||
rv = view_file (opts->params[i], NULL);
|
||||
|
||||
mu_msg_gmime_uninit();
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user