about summary refs log tree commit homepage
path: root/lib/PublicInbox/IMAP.pm
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-02-07 08:52:00 +0000
committerEric Wong <e@80x24.org>2021-02-07 22:57:29 +0000
commit18798ea686b3c5cc46831e6b3bd1dec0cefa3137 (patch)
tree41d6fa97cac6263bd9564e3fd43660a609aee1c7 /lib/PublicInbox/IMAP.pm
parent5beb4a5f6585acdb036a10b2be4b45b6e7613ed6 (diff)
downloadpublic-inbox-18798ea686b3c5cc46831e6b3bd1dec0cefa3137.tar.gz
None of the Content-Type attributes are long-lived
(and unlikely to be memory intensive).  While these
callsites won't trigger $DB::args segfaults via
confess or longmess, it'll make future code audits
easier.

cf. commit 0795b0906cc81f40
    ("ds: guard against stack-not-refcounted quirk of Perl 5")
Diffstat (limited to 'lib/PublicInbox/IMAP.pm')
-rw-r--r--lib/PublicInbox/IMAP.pm6
1 files changed, 3 insertions, 3 deletions
diff --git a/lib/PublicInbox/IMAP.pm b/lib/PublicInbox/IMAP.pm
index 226e98a2..af8ce72b 100644
--- a/lib/PublicInbox/IMAP.pm
+++ b/lib/PublicInbox/IMAP.pm
@@ -499,7 +499,7 @@ sub body_disposition ($) {
         my $cd = $eml->header_raw('Content-Disposition') or return 'NIL';
         $cd = parse_content_disposition($cd);
         my $buf = '('._esc($cd->{type});
-        $buf .= ' ' . _esc_hash(delete $cd->{attributes});
+        $buf .= ' ' . _esc_hash($cd->{attributes});
         $buf .= ')';
 }
 
@@ -511,7 +511,7 @@ sub body_leaf ($$;$) {
         my $ct = $eml->ct;
         $buf .= '('._esc($ct->{type}).' ';
         $buf .= _esc($ct->{subtype});
-        $buf .= ' ' . _esc_hash(delete $ct->{attributes});
+        $buf .= ' ' . _esc_hash($ct->{attributes});
         $buf .= ' ' . _esc($eml->header_raw('Content-ID'));
         $buf .= ' ' . _esc($eml->header_raw('Content-Description'));
         my $cte = $eml->header_raw('Content-Transfer-Encoding') // '7bit';
@@ -540,7 +540,7 @@ sub body_parent ($$$) {
                 $buf .= @$hold ? join('', @$hold) : 'NIL';
                 $buf .= ' '._esc($ct->{subtype});
                 if ($structure) {
-                        $buf .= ' '._esc_hash(delete $ct->{attributes});
+                        $buf .= ' '._esc_hash($ct->{attributes});
                         $buf .= ' '.body_disposition($eml);
                         $buf .= ' '._esc($eml->header_raw('Content-Language'));
                         $buf .= ' '._esc($eml->header_raw('Content-Location'));