From: martin f. krafft Date: Wed, 21 Nov 2007 10:51:00 +0000 (+0100) Subject: make retrain incron compatible X-Git-Url: https://git.madduck.net/etc/mailfilter.git/commitdiff_plain/24471f4714a7838630b60b2ba63391b8f459daa4 make retrain incron compatible --- diff --git a/bin/retrain b/bin/retrain index b1ccca1..784f17e 100755 --- a/bin/retrain +++ b/bin/retrain @@ -10,18 +10,22 @@ PAUSETIME=10 HAM=0 SPAM=0 -MAILDIR= +maildir= +files= for i in "$@"; do case "$i" in --ham) HAM=1;; --spam) SPAM=1;; *) - if [ -n "$MAILDIR" ]; then - echo "E: Maildir already specified: $i" >&2 - exit 1 + if [ -f "$i" ] && [ -r "$i" ]; then + files="$files $i" elif [ -d "$i"/cur ] && [ -d "$i"/new ] && [ -d "$i"/tmp ]; then - MAILDIR="$i" + if [ -n "$maildir" ]; then + echo "E: Maildir already specified: $i" >&2 + exit 1 + fi + maildir="$i" else echo "E: unknown argument: $i" >&2 exit 255 @@ -44,14 +48,18 @@ case "$HAM/$SPAM" in 1/0) ARG=--ham;; esac -LOCKFILE="$MAILDIR/.retrain.lock" -trap "rm -f $LOCKFILE" 1 2 3 4 5 6 7 8 10 11 12 13 14 15 -if ! lockfile -0 -r0 -l 3600 "$LOCKFILE" 2>/dev/null; then - echo "E: another retrain process is already running over that Maildir." >&2 - exit 1 +if [ -n "$maildir" ]; then + LOCKFILE="$maildir/.retrain.lock" + trap "rm -f $LOCKFILE" 1 2 3 4 5 6 7 8 10 11 12 13 14 15 + if ! lockfile -0 -r0 -l 3600 "$LOCKFILE" 2>/dev/null; then + echo "E: another retrain process is already running over that Maildir." >&2 + exit 1 + fi + + files="$files $(find $MAILDIR/cur $MAILDIR/new -type f)" fi -find $MAILDIR/cur $MAILDIR/new -type f | while read msg; do +for msg in $files; do $NICE ${0%/*}/train $ARG "$msg" | $RESUBMIT || ret=$? case "${ret:-0}" in 0|75) :;; @@ -64,7 +72,9 @@ find $MAILDIR/cur $MAILDIR/new -type f | while read msg; do sleep $PAUSETIME done -rm -f "$LOCKFILE" -trap - 1 2 3 4 5 6 7 8 10 11 12 13 14 15 +if [ -n "${LOCKFILE:-}" ]; then + rm -f "$LOCKFILE" + trap - 1 2 3 4 5 6 7 8 10 11 12 13 14 15 +fi exit 0