mirror of
https://github.com/fergalmoran/ladybird.git
synced 2025-12-22 09:19:03 +00:00
WebContent: Remove unused class "ImageCodecPluginSerenity"
This commit is contained in:
@@ -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;
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user