Path: ...!news.mixmin.net!aioe.org!news.alphanet.ch!alphanet.ch!.POSTED.catalyst.alphanet.ch!not-for-mail From: Marc SCHAEFER Newsgroups: fr.usenet.abus.d Subject: Re: =?ISO-8859-1?Q?vir=E9?= de eternal-september.org ? Date: Mon, 16 May 2022 14:41:44 -0000 (UTC) Organization: Posted through ALPHANET Message-ID: References: <6hs28htd6fvp9jfhanogilavghc0q805a1@consensus-omnium> <9cs38h9g7vo0j8df60k05pvpv9se7en6tl@consensus-omnium> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 8bit Injection-Date: Mon, 16 May 2022 14:41:44 -0000 (UTC) Injection-Info: shakotay.alphanet.ch; posting-account="schaefer"; posting-host="catalyst.alphanet.ch:192.168.99.121"; logging-data="28348"; mail-complaints-to="usenet@alphanet.ch" User-Agent: tin/2.4.3-20181224 ("Glen Mhor") (UNIX) (Linux/4.19.0-20-amd64 (x86_64)) Cancel-Lock: sha256:9d1N93II+ybY6ypb6w1699CclrFaQwXH7dGhdt0sTH0= Bytes: 2450 Lines: 37 Marc SCHAEFER wrote: > Donc, quand un Cancel-Lock est placé en entête de continuation, il ne > peut être annulé par un Cancel-Key correct. Et ce sont bien des espaces > 0x20. Le bug est dans cleanfeed.local, fonction verify_cancel(): my $headers = INN::head($target) || return "$descr of non-existing ID $target"; my %headers; for my $line(split(/\s*\n/, $headers)) { if ($line =~ m/^([[:alnum:]-]+):\s+(.*)/) { # assuming low/upcase normalisation by INN $headers{$1} = $2; } } Ceci ne traite pas les lignes de continuation. Ce code si: my %headers; my $previous; for my $line(split(/\s*\n/, $art)) { if ($line =~ m/^([[:alnum:]-]+):\s+(.*)/) { # assuming low/upcase normalisation by INN $headers{$1} = $2; $previous = $1; } elsif ($line =~ m/^\s+(.*)/) { if (defined($previous)) { $headers{$previous} .= " " . $1; } else { INN::syslog('notice', 'garbled line: ' . $line); } } }