# HG changeset patch # User bears # Date 1004445733 0 # Node ID a4e9a20e50e5dd9c55ceba5248f2c9bd1659a306 # Parent 021d145e34e93675291feb55ac33f11eafaa4bbe [svn] * docs/noffle.conf.5,src/configfile.c,src/filter.h,src/filter.c: Contrary to the documentation, the action of a filter if not specified was 'full'. Add a new 'default' action which makes the action that of the group's subscription mode. Make this the default action, and allow 'default' to be specified explicitly as the action in the filter definition. Adapted from patch submitted by Mirko Liss. Thanks, Mirko. * docs/noffle.conf.5: Correct small typo. diff -r 021d145e34e9 -r a4e9a20e50e5 ChangeLog --- a/ChangeLog Mon Oct 22 14:41:43 2001 +0100 +++ b/ChangeLog Tue Oct 30 12:42:13 2001 +0000 @@ -1,3 +1,13 @@ +Tur Oct 30 2001 Jim Hague + +* docs/noffle.conf.5,src/configfile.c,src/filter.h,src/filter.c: + Contrary to the documentation, the action of a filter if not specified + was 'full'. Add a new 'default' action which makes the action that of the + group's subscription mode. Make this the default action, and allow + 'default' to be specified explicitly as the action in the filter + definition. Adapted from patch submitted by Mirko Liss. Thanks, Mirko. +* docs/noffle.conf.5: Correct small typo. + Mon Oct 22 2001 Jim Hague * src/fetch.c: Only leave articles in the requested list if the error @@ -38,7 +48,7 @@ Wed Sep 12 2001 Jim Hague * src/client.c,src/client.h,src/fetch.c,src/noffle.c,src/server.c: - robustness - instead of retruning simple Passed/Failed statuses from + robustness - instead of returning simple Passed/Failed statuses from connection functions, return an integer status instead. This allows Noffle to distinguish between a connection failure, an unrecoverable protocol error and a recoverable problem. As a concrete instance, Noffle diff -r 021d145e34e9 -r a4e9a20e50e5 docs/noffle.conf.5 --- a/docs/noffle.conf.5 Mon Oct 22 14:41:43 2001 +0100 +++ b/docs/noffle.conf.5 Tue Oct 30 12:42:13 2001 +0000 @@ -1,5 +1,5 @@ .TH noffle.conf 5 -.\" $Id: noffle.conf.5 311 2001-10-21 11:00:12Z bears $ +.\" $Id: noffle.conf.5 313 2001-10-30 12:42:13Z bears $ .SH NAME noffle.conf \- Configuration file for NOFFLE news server @@ -140,7 +140,7 @@ .TP .B auto-unsubscribe yes|no Automatically remove groups from fetch list if they have not been -accessed for a number days. Groups are only unsubscribed if there +accessed for a number of days. Groups are only unsubscribed if there are fresh articles arriving and remaining unread. .br Default: no @@ -345,9 +345,11 @@ .PP .B action = -.IR "full|over|thread|discard" . -Specifies the action to be taken if the filter matches. If not specified, -the default action is as specified by the group's default subscription mode. +.IR "full|over|thread|discard|default" . +Specifies the action to be taken if the filter matches. If not specified +or specified as +.BR default , +the action is as specified by the group's subscription mode. .PP .B group = diff -r 021d145e34e9 -r a4e9a20e50e5 src/configfile.c --- a/src/configfile.c Mon Oct 22 14:41:43 2001 +0100 +++ b/src/configfile.c Tue Oct 30 12:42:13 2001 +0000 @@ -6,7 +6,7 @@ SPOOLDIR VERSION - $Id: configfile.c 309 2001-10-05 15:44:22Z enz $ + $Id: configfile.c 313 2001-10-30 12:42:13Z bears $ */ #if HAVE_CONFIG_H @@ -780,6 +780,8 @@ f->action = FILTER_THREAD; else if ( strcmp( value, "discard" ) == 0 ) f->action = FILTER_DISCARD; + else if ( strcmp( value, "default" ) == 0 ) + f->action = FILTER_DEFAULT; seenAction = TRUE; } else if ( rule.type == RULE_NEWSGROUP ) diff -r 021d145e34e9 -r a4e9a20e50e5 src/filter.c --- a/src/filter.c Mon Oct 22 14:41:43 2001 +0100 +++ b/src/filter.c Tue Oct 30 12:42:13 2001 +0000 @@ -3,7 +3,7 @@ Article filtering. - $Id: filter.c 300 2001-08-05 08:24:22Z bears $ + $Id: filter.c 313 2001-10-30 12:42:13Z bears $ */ #if HAVE_CONFIG_H @@ -192,7 +192,8 @@ /* * Run the rules over the supplied overview. If a specific rule fires, - * returns its action. If no rule fires, return the default read mode. + * returns its action. If no rule fires, or a rule specifying the default + * action fires, return the default read mode. */ FilterAction Flt_checkFilters( const char *thisGrp, const char *newsgroups, @@ -203,10 +204,15 @@ for ( i = 0; i < filter.nFilters; i++ ) if ( checkFilter( thisGrp, newsgroups, ov, filter.filters[ i ] ) ) { + FilterAction action = filter.filters[ i ]->action; + Log_dbg( LOG_DBG_FILTER, "Filter %d fired on message %s", i, Ov_msgId( ov ) ); - return filter.filters[ i ]->action; + if ( action == FILTER_DEFAULT ) + break; + else + return action; } switch( mode ) @@ -233,7 +239,7 @@ f->nRules = 0; f->maxRules = 0; f->rules = NULL; - f->action = FILTER_FULL; + f->action = FILTER_DEFAULT; return f; } diff -r 021d145e34e9 -r a4e9a20e50e5 src/filter.h --- a/src/filter.h Mon Oct 22 14:41:43 2001 +0100 +++ b/src/filter.h Tue Oct 30 12:42:13 2001 +0000 @@ -3,7 +3,7 @@ Article filtering. - $Id: filter.h 189 2000-08-09 21:19:17Z bears $ + $Id: filter.h 313 2001-10-30 12:42:13Z bears $ */ #ifndef FILTER_H @@ -19,7 +19,8 @@ FILTER_FULL, FILTER_XOVER, FILTER_THREAD, - FILTER_DISCARD + FILTER_DISCARD, + FILTER_DEFAULT } FilterAction; /* Representation of a rule. */