aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
Diffstat (limited to 'mail')
-rw-r--r--mail/ChangeLog11
-rw-r--r--mail/em-folder-view.c2
-rw-r--r--mail/em-junk-filter.c40
3 files changed, 34 insertions, 19 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 3c0c219b7d..59a144e955 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,8 +1,19 @@
2004-02-06 Radek Doulik <rodo@ximian.com>
+ * em-folder-view.c (emfv_popup_mark_nojunk): move to the next
+ message after mark not junk as well
+
* em-junk-filter.c (em_junk_sa_test_spamd): split into
spamassassin and spamd tests
(em_junk_sa_is_available): test spamd only if spamd usage enabled
+ (pipe_to_sa_with_error): extended pipe_to_sa, last added parametr
+ specifies return value if an error occured
+ (em_junk_sa_check_junk): don't use /bin/sh -c when running
+ spamassassin, it's not needed and we need to avoid getting 126,127
+ exit codes from the shell
+ (em_junk_sa_check_junk): pass 0 rv_err to pipe_to_sa_with_error to
+ avoid false positives in case someone removes/uninstalls SA while
+ evolution runs
2004-02-06 Not Zed <NotZed@Ximian.com>
diff --git a/mail/em-folder-view.c b/mail/em-folder-view.c
index 1125f9629c..dfad679d16 100644
--- a/mail/em-folder-view.c
+++ b/mail/em-folder-view.c
@@ -598,6 +598,8 @@ emfv_popup_mark_nojunk (GtkWidget *w, EMFolderView *emfv)
uids = message_list_get_selected(emfv->list);
em_folder_view_mark_selected(emfv, CAMEL_MESSAGE_JUNK, 0);
+ if (uids->len == 1)
+ message_list_select(emfv->list, MESSAGE_LIST_SELECT_NEXT, 0, 0, FALSE);
mail_mark_junk(emfv->folder, uids, FALSE);
}
diff --git a/mail/em-junk-filter.c b/mail/em-junk-filter.c
index 29e618205f..8c178a0fe9 100644
--- a/mail/em-junk-filter.c
+++ b/mail/em-junk-filter.c
@@ -95,7 +95,7 @@ em_junk_sa_get_daemon_port ()
}
static int
-pipe_to_sa (CamelMimeMessage *msg, const char *in, char **argv)
+pipe_to_sa_with_error (CamelMimeMessage *msg, const char *in, char **argv, int rv_err)
{
int result, status, errnosav, fds[2];
CamelStream *stream;
@@ -116,7 +116,7 @@ pipe_to_sa (CamelMimeMessage *msg, const char *in, char **argv)
errnosav = errno;
d(printf ("failed to create a pipe (for use with spamassassin: %s\n", strerror (errno)));
errno = errnosav;
- return -1;
+ return rv_err;
}
if (!(pid = fork ())) {
@@ -128,7 +128,7 @@ pipe_to_sa (CamelMimeMessage *msg, const char *in, char **argv)
if (dup2 (fds[0], STDIN_FILENO) == -1 ||
dup2 (nullfd, STDOUT_FILENO) == -1 ||
dup2 (nullfd, STDERR_FILENO) == -1)
- _exit (255);
+ _exit (rv_err & 0377);
setsid ();
@@ -137,13 +137,13 @@ pipe_to_sa (CamelMimeMessage *msg, const char *in, char **argv)
fcntl (fd, F_SETFD, FD_CLOEXEC);
execvp (argv[0], argv);
- _exit (255);
+ _exit (rv_err & 0377);
} else if (pid < 0) {
errnosav = errno;
close (fds[0]);
close (fds[1]);
errno = errnosav;
- return -1;
+ return rv_err;
}
/* parent process */
@@ -178,7 +178,13 @@ pipe_to_sa (CamelMimeMessage *msg, const char *in, char **argv)
if (result != -1 && WIFEXITED (status))
return WEXITSTATUS (status);
else
- return -1;
+ return rv_err;
+}
+
+static int
+pipe_to_sa (CamelMimeMessage *msg, const char *in, char **argv)
+{
+ return pipe_to_sa_with_error (msg, in, argv, -1);
}
static int
@@ -206,10 +212,9 @@ em_junk_sa_test_spamd_running (int port)
static void
em_junk_sa_test_spamassassin (void)
{
- char *argv[4] = {
- "/bin/sh",
- "-c",
- "spamassassin --version",
+ char *argv [3] = {
+ "spamassassin",
+ "--version",
NULL,
};
@@ -304,7 +309,7 @@ static gboolean
em_junk_sa_check_junk (CamelMimeMessage *msg)
{
char *argv[5], buf[12];
- int i = 0;
+ int i = 0, rv;
d(fprintf (stderr, "em_junk_sa_check_junk\n"));
@@ -320,18 +325,15 @@ em_junk_sa_check_junk (CamelMimeMessage *msg)
argv[i++] = buf;
}
} else {
- argv[i++] = "/bin/sh";
- argv[i++] = "-c";
-
+ argv [i++] = "spamassassin";
+ argv [i++] = "--exit-code";
if (em_junk_sa_get_local_only ())
- argv[i++] = "spamassassin --exit-code --local";
- else
- argv[i++] = "spamassassin --exit-code";
+ argv [i++] = "--local";
}
argv[i] = NULL;
-
- return pipe_to_sa (msg, NULL, argv);
+
+ return pipe_to_sa_with_error (msg, NULL, argv, 0) != 0;
}
static void