Better handling of the matches rule member.

Signed-off-by: Tom Eastep <teastep@shorewall.net>
This commit is contained in:
Tom Eastep 2013-04-17 10:39:32 -07:00
parent ef01748dc9
commit 938bd72844

View File

@ -812,6 +812,7 @@ sub set_rule_option( $$$ ) {
}
push @{$ruleref->{$option}}, ( reftype $value ? @$value : $value );
push @{$ruleref->{matches}}, $option;
} else {
assert( ! reftype $value );
$ruleref->{$option} = join(' ', $value1, $value ) unless $value1 eq $value;
@ -834,10 +835,9 @@ sub set_rule_option( $$$ ) {
}
} else {
$ruleref->{$option} = $value;
}
push @{$ruleref->{matches}}, $option;
}
}
sub transform_rule( $;\$ ) {
my ( $input, $completeref ) = @_;
@ -1330,15 +1330,16 @@ sub push_matches {
if ( $globals{KLUDGEFREE} ) {
$ruleref->{$option} = [ $curvalue ] unless reftype $curvalue;
push @{$ruleref->{$option}}, reftype $value ? @$value : $value;
push @{$ruleref->{matches}}, $option;
} else {
$ruleref->{$option} = join( '', $curvalue, $value );
}
} else {
$ruleref->{$option} = $value;
$dont_optimize ||= $option =~ /^[piosd]$/ && $value =~ /^!/;
push @{$ruleref->{matches}}, $option;
}
push @{$ruleref->{matches}}, $option;
}
DONT_OPTIMIZE if $dont_optimize;