# HG changeset patch # User Pavel Jank # Date 1025898994 0 # Node ID 81235cad75cb29566ae8a40071cdfb265f116064 # Parent 24320eec547adb0274939f2564fbc8d71ec55735 Obey the rmail file and use the unpruned header properly. diff -r 24320eec547a -r 81235cad75cb lib-src/b2m.pl --- a/lib-src/b2m.pl Fri Jul 05 19:03:19 2002 +0000 +++ b/lib-src/b2m.pl Fri Jul 05 19:56:34 2002 +0000 @@ -30,7 +30,7 @@ use Date::Parse; my($whoami) = basename $0; -my($version) = '$Revision: 1.4 $'; +my($version) = '$Revision: 1.1 $'; my($usage) = "Usage: $whoami [--help] [--version] [--[no]full-headers] [Babyl-file] \tBy default, full headers are printed.\n"; @@ -62,7 +62,7 @@ while (<>) { my($msg_num) = $. - 1; - my($labels, $full_header, $header); + my($labels, $pruned, $full_header, $header); my($from_line, $from_addr); my($time); @@ -79,7 +79,11 @@ } $labels = $1; - s/(?:((?:.+\n)+)\n+)?\*\*\* EOOH \*\*\*\n+// || goto malformatted; + # Strip the integer indicating whether the header is pruned + $labels =~ s/^(\d+)[,\s]*//; + $pruned = $1; + + s/(?:((?:.+\n)+)\n*)?\*\*\* EOOH \*\*\*\n+// || goto malformatted; $full_header = $1; if (s/((?:.+\n)+)\n+//) { @@ -91,7 +95,10 @@ $_ = ''; } - if (! $full_header) { + # "$pruned eq '0'" is different from "! $pruned". We want to make + # sure that we found a valid label line which explicitly indicated + # that the header was not pruned. + if ((! $full_header) || ($pruned eq '0')) { $full_header = $header; } @@ -101,8 +108,6 @@ # Quote "^From " s/(^|\n)From /$1>From /g; - # Strip the integer indicating whether the header is pruned - $labels =~ s/^\d+[,\s]*//; # Strip extra commas and whitespace from the end $labels =~ s/[,\s]+$//; # Now collapse extra commas and whitespace in the remaining label string