LibWeb: Make TextEncoder GC-allocated

This commit is contained in:
Andreas Kling 2022-09-04 10:56:37 +02:00
parent 57db2529cf
commit 7e508456a0
Notes: sideshowbarker 2024-07-17 09:41:18 +09:00
4 changed files with 25 additions and 21 deletions

View file

@ -8,15 +8,26 @@
#include <LibJS/Runtime/TypedArray.h>
#include <LibWeb/Bindings/Wrapper.h>
#include <LibWeb/Encoding/TextEncoder.h>
#include <LibWeb/HTML/Window.h>
namespace Web::Encoding {
JS::NonnullGCPtr<TextEncoder> TextEncoder::create_with_global_object(HTML::Window& window)
{
return *window.heap().allocate<TextEncoder>(window.realm(), window);
}
TextEncoder::TextEncoder(HTML::Window& window)
: PlatformObject(window.realm())
{
set_prototype(&window.cached_web_prototype("TextEncoder"));
}
TextEncoder::~TextEncoder() = default;
// https://encoding.spec.whatwg.org/#dom-textencoder-encode
JS::Uint8Array* TextEncoder::encode(String const& input) const
{
auto& vm = wrapper()->vm();
auto& realm = *vm.current_realm();
// NOTE: The AK::String returned from PrimitiveString::string() is always UTF-8, regardless of the internal string type, so most of these steps are no-ops.
// 1. Convert input to an I/O queue of scalar values.
@ -29,8 +40,8 @@ JS::Uint8Array* TextEncoder::encode(String const& input) const
auto byte_buffer = input.to_byte_buffer();
auto array_length = byte_buffer.size();
auto* array_buffer = JS::ArrayBuffer::create(realm, move(byte_buffer));
return JS::Uint8Array::create(realm, array_length, *array_buffer);
auto* array_buffer = JS::ArrayBuffer::create(realm(), move(byte_buffer));
return JS::Uint8Array::create(realm(), array_length, *array_buffer);
}
// https://encoding.spec.whatwg.org/#dom-textencoder-encoding

View file

@ -16,21 +16,13 @@
namespace Web::Encoding {
// https://encoding.spec.whatwg.org/#textencoder
class TextEncoder
: public RefCounted<TextEncoder>
, public Bindings::Wrappable {
class TextEncoder final : public Bindings::PlatformObject {
WEB_PLATFORM_OBJECT(TextEncoder, Bindings::PlatformObject);
public:
using WrapperType = Bindings::TextEncoderWrapper;
static JS::NonnullGCPtr<TextEncoder> create_with_global_object(HTML::Window&);
static NonnullRefPtr<TextEncoder> create()
{
return adopt_ref(*new TextEncoder());
}
static NonnullRefPtr<TextEncoder> create_with_global_object(HTML::Window&)
{
return TextEncoder::create();
}
virtual ~TextEncoder() override;
JS::Uint8Array* encode(String const& input) const;
@ -38,7 +30,9 @@ public:
protected:
// https://encoding.spec.whatwg.org/#dom-textencoder
TextEncoder() = default;
explicit TextEncoder(HTML::Window&);
};
}
WRAPPER_HACK(TextEncoder, Web::Encoding)

View file

@ -462,7 +462,6 @@ class RangePrototype;
class ResizeObserverWrapper;
class SelectionWrapper;
class TextDecoderWrapper;
class TextEncoderWrapper;
class URLSearchParamsIteratorWrapper;
class URLSearchParamsWrapper;
class URLWrapper;

View file

@ -52,7 +52,7 @@ libweb_js_wrapper(DOM/Text NO_INSTANCE)
libweb_js_wrapper(DOM/TreeWalker NO_INSTANCE)
libweb_js_wrapper(DOMParsing/XMLSerializer NO_INSTANCE)
libweb_js_wrapper(Encoding/TextDecoder)
libweb_js_wrapper(Encoding/TextEncoder)
libweb_js_wrapper(Encoding/TextEncoder NO_INSTANCE)
libweb_js_wrapper(Fetch/Headers ITERABLE)
libweb_js_wrapper(FileAPI/Blob)
libweb_js_wrapper(FileAPI/File)