X-Git-Url: http://www.git.stargrave.org/?p=public-inbox.git;a=blobdiff_plain;f=lib%2FPublicInbox%2FMsgIter.pm;h=d9df32abc37c7fc7da68c0e09ed2f942ddbb4827;hp=f11ba223c93362a985285555e4113feab87684f1;hb=e5cc97f6a2ff53f072a5d692e56d0918b33c5081;hpb=130af18f06ae9b91e07985ff56b4dd90cedbd744 diff --git a/lib/PublicInbox/MsgIter.pm b/lib/PublicInbox/MsgIter.pm index f11ba223..d9df32ab 100644 --- a/lib/PublicInbox/MsgIter.pm +++ b/lib/PublicInbox/MsgIter.pm @@ -45,12 +45,18 @@ sub msg_part_text ($$) { # times when it should not have been: # <87llgalspt.fsf@free.fr> # <200308111450.h7BEoOu20077@mail.osdl.org> - if ($err && ($ct =~ m!\btext/plain\b!i || + if ($err && ($ct =~ m!\btext/\b!i || $ct =~ m!\bmultipart/mixed\b!i)) { - # Try to assume UTF-8 because Alpine seems to - # do wacky things and set charset=X-UNKNOWN - $part->charset_set('UTF-8'); - $s = eval { $part->body_str }; + my $cte = $part->header_raw('Content-Transfer-Encoding'); + if (defined($cte) && $cte =~ /\b7bit\b/i) { + $s = $part->body; + $err = undef if $s =~ /\A[[:ascii:]]+\z/s; + } else { + # Try to assume UTF-8 because Alpine seems to + # do wacky things and set charset=X-UNKNOWN + $part->charset_set('UTF-8'); + $s = eval { $part->body_str }; + } # If forcing charset=UTF-8 failed, # caller will warn further down...