mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-08-31 14:48:17 +00:00
WebContent: Remove unused class "ImageCodecPluginSerenity"
This commit is contained in:
parent
458af2d2a9
commit
f4c03d548e
Notes:
github-actions[bot]
2024-12-13 14:44:56 +00:00
Author: https://github.com/rmg-x
Commit: f4c03d548e
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/2897
Reviewed-by: https://github.com/AtkinsSJ ✅
2 changed files with 0 additions and 81 deletions
|
@ -1,51 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2022, Dex♪ <dexes.ttp@gmail.com>
|
|
||||||
* Copyright (c) 2022, Andreas Kling <andreas@ladybird.org>
|
|
||||||
*
|
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "ImageCodecPluginSerenity.h"
|
|
||||||
#include <LibImageDecoderClient/Client.h>
|
|
||||||
|
|
||||||
namespace WebContent {
|
|
||||||
|
|
||||||
ImageCodecPluginSerenity::ImageCodecPluginSerenity() = default;
|
|
||||||
ImageCodecPluginSerenity::~ImageCodecPluginSerenity() = default;
|
|
||||||
|
|
||||||
NonnullRefPtr<Core::Promise<Web::Platform::DecodedImage>> ImageCodecPluginSerenity::decode_image(ReadonlyBytes bytes, Function<ErrorOr<void>(Web::Platform::DecodedImage&)> on_resolved, Function<void(Error&)> on_rejected)
|
|
||||||
{
|
|
||||||
if (!m_client) {
|
|
||||||
m_client = ImageDecoderClient::Client::try_create().release_value_but_fixme_should_propagate_errors();
|
|
||||||
m_client->on_death = [&] {
|
|
||||||
m_client = nullptr;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
auto promise = Core::Promise<Web::Platform::DecodedImage>::construct();
|
|
||||||
if (on_resolved)
|
|
||||||
promise->on_resolution = move(on_resolved);
|
|
||||||
if (on_rejected)
|
|
||||||
promise->on_rejection = move(on_rejected);
|
|
||||||
|
|
||||||
auto image_decoder_promise = m_client->decode_image(
|
|
||||||
bytes,
|
|
||||||
[promise](ImageDecoderClient::DecodedImage& result) -> ErrorOr<void> {
|
|
||||||
// FIXME: Remove this codec plugin and just use the ImageDecoderClient directly to avoid these copies
|
|
||||||
Web::Platform::DecodedImage decoded_image;
|
|
||||||
decoded_image.is_animated = result.is_animated;
|
|
||||||
decoded_image.loop_count = result.loop_count;
|
|
||||||
for (auto const& frame : result.frames) {
|
|
||||||
decoded_image.frames.empend(move(frame.bitmap), frame.duration);
|
|
||||||
}
|
|
||||||
promise->resolve(move(decoded_image));
|
|
||||||
return {};
|
|
||||||
},
|
|
||||||
[promise](auto& error) {
|
|
||||||
promise->reject(Error::copy(error));
|
|
||||||
});
|
|
||||||
|
|
||||||
return promise;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,30 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2022, Dex♪ <dexes.ttp@gmail.com>
|
|
||||||
* Copyright (c) 2022, Andreas Kling <andreas@ladybird.org>
|
|
||||||
*
|
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include <AK/RefPtr.h>
|
|
||||||
#include <LibWeb/Platform/ImageCodecPlugin.h>
|
|
||||||
|
|
||||||
namespace ImageDecoderClient {
|
|
||||||
class Client;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace WebContent {
|
|
||||||
|
|
||||||
class ImageCodecPluginSerenity final : public Web::Platform::ImageCodecPlugin {
|
|
||||||
public:
|
|
||||||
ImageCodecPluginSerenity();
|
|
||||||
virtual ~ImageCodecPluginSerenity() override;
|
|
||||||
|
|
||||||
virtual NonnullRefPtr<Core::Promise<Web::Platform::DecodedImage>> decode_image(ReadonlyBytes, ESCAPING Function<ErrorOr<void>(Web::Platform::DecodedImage&)> on_resolved, ESCAPING Function<void(Error&)> on_rejected) override;
|
|
||||||
|
|
||||||
private:
|
|
||||||
RefPtr<ImageDecoderClient::Client> m_client;
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
Loading…
Add table
Add a link
Reference in a new issue