mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-11 01:06:01 +03:00
ImageDecoder: Fix assertion after failed decode
We were calling value() on an ErrorOr containing an error when trying to extract the frame duration after a failed decode. This fixes ImageDecoder crashing on various websites.
This commit is contained in:
parent
dcc7d7d566
commit
da42c1552c
Notes:
sideshowbarker
2024-07-18 00:32:32 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/da42c1552c9
@ -53,11 +53,14 @@ Messages::ImageDecoderServer::DecodeImageResponse ClientConnection::decode_image
|
||||
Vector<u32> durations;
|
||||
for (size_t i = 0; i < decoder->frame_count(); ++i) {
|
||||
auto frame_or_error = decoder->frame(i);
|
||||
if (frame_or_error.is_error() || !frame_or_error.value().image)
|
||||
if (frame_or_error.is_error()) {
|
||||
bitmaps.append(Gfx::ShareableBitmap {});
|
||||
else
|
||||
bitmaps.append(frame_or_error.value().image->to_shareable_bitmap());
|
||||
durations.append(frame_or_error.value().duration);
|
||||
durations.append(0);
|
||||
} else {
|
||||
auto frame = frame_or_error.release_value();
|
||||
bitmaps.append(frame.image->to_shareable_bitmap());
|
||||
durations.append(frame.duration);
|
||||
}
|
||||
}
|
||||
|
||||
return { decoder->is_animated(), static_cast<u32>(decoder->loop_count()), bitmaps, durations };
|
||||
|
Loading…
Reference in New Issue
Block a user