diff options
| -rw-r--r-- | Changelog | 2 | ||||
| -rw-r--r-- | lib/Net/IMAP/InterIMAP.pm | 7 | 
2 files changed, 6 insertions, 3 deletions
| @@ -80,6 +80,8 @@ interimap (0.5) upstream;     always mentioned ~/, which on POSIX-compliant systems expands to the     value of the variable HOME.  (Cf. Shell and Utilities volume of     POSIX.1-2017, sec. 2.6.1.) + - libinterimap: don't panic() when inflate() reports the end of the +   compression stream is reached.   -- Guilhem Moulin <guilhem@fripost.org>  Fri, 10 May 2019 00:58:14 +0200 diff --git a/lib/Net/IMAP/InterIMAP.pm b/lib/Net/IMAP/InterIMAP.pm index 9c95109..2d1f644 100644 --- a/lib/Net/IMAP/InterIMAP.pm +++ b/lib/Net/IMAP/InterIMAP.pm @@ -20,7 +20,7 @@ package Net::IMAP::InterIMAP v0.0.5;  use warnings;  use strict; -use Compress::Raw::Zlib qw/Z_OK Z_FULL_FLUSH Z_SYNC_FLUSH MAX_WBITS/; +use Compress::Raw::Zlib qw/Z_OK Z_STREAM_END Z_FULL_FLUSH Z_SYNC_FLUSH MAX_WBITS/;  use Config::Tiny ();  use Errno qw/EEXIST EINTR/;  use Net::SSLeay 1.73 (); @@ -1723,8 +1723,9 @@ sub _getline($;$) {              $self->{_OUTRAWCOUNT} += $n;              if (defined (my $i = $self->{_Z_INFLATE})) { -                $i->inflate($buf, $self->{_OUTBUF}) == Z_OK or -                    $self->panic("Inflation failed: ", $i->msg()); +                my $r = $i->inflate($buf, $self->{_OUTBUF}); +                $self->panic("Inflation failed: $r ", $i->msg()) +                    unless $r == Z_OK or $r == Z_STREAM_END;              }              else {                  $self->{_OUTBUF} = $buf; | 
