From ff5243cc16570cb1d06871eacf409ac87704b22c Mon Sep 17 00:00:00 2001 From: Nicolas Grekas Date: Fri, 10 Nov 2023 11:00:41 +0100 Subject: [PATCH] Fix error handling in Stream::getContents() --- src/Stream.php | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/src/Stream.php b/src/Stream.php index d3bd78d..6b56cbb 100644 --- a/src/Stream.php +++ b/src/Stream.php @@ -260,8 +260,22 @@ public function getContents(): string throw new \RuntimeException('Stream is detached'); } - if (false === $contents = @\stream_get_contents($this->stream)) { - throw new \RuntimeException('Unable to read stream contents: ' . (\error_get_last()['message'] ?? '')); + $exception = null; + + set_error_handler(static function ($type, $message) use (&$exception) { + $exception = new \RuntimeException('Unable to read from stream: ' . $message); + }); + + try { + $contents = stream_get_contents($this->stream); + } catch (\Throwable $e) { + $exception = new \RuntimeException('Unable to read from stream: ' . $e->getMessage(), 0, $e); + } + + restore_error_handler(); + + if ($exception) { + throw $exception; } return $contents;