mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 13:27:35 +00:00
LibWeb: Make TextEncoder GC-allocated
This commit is contained in:
parent
57db2529cf
commit
7e508456a0
4 changed files with 25 additions and 21 deletions
|
@ -8,15 +8,26 @@
|
||||||
#include <LibJS/Runtime/TypedArray.h>
|
#include <LibJS/Runtime/TypedArray.h>
|
||||||
#include <LibWeb/Bindings/Wrapper.h>
|
#include <LibWeb/Bindings/Wrapper.h>
|
||||||
#include <LibWeb/Encoding/TextEncoder.h>
|
#include <LibWeb/Encoding/TextEncoder.h>
|
||||||
|
#include <LibWeb/HTML/Window.h>
|
||||||
|
|
||||||
namespace Web::Encoding {
|
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
|
// https://encoding.spec.whatwg.org/#dom-textencoder-encode
|
||||||
JS::Uint8Array* TextEncoder::encode(String const& input) const
|
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.
|
// 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.
|
// 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 byte_buffer = input.to_byte_buffer();
|
||||||
auto array_length = byte_buffer.size();
|
auto array_length = byte_buffer.size();
|
||||||
auto* array_buffer = JS::ArrayBuffer::create(realm, move(byte_buffer));
|
auto* array_buffer = JS::ArrayBuffer::create(realm(), move(byte_buffer));
|
||||||
return JS::Uint8Array::create(realm, array_length, *array_buffer);
|
return JS::Uint8Array::create(realm(), array_length, *array_buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://encoding.spec.whatwg.org/#dom-textencoder-encoding
|
// https://encoding.spec.whatwg.org/#dom-textencoder-encoding
|
||||||
|
|
|
@ -16,21 +16,13 @@
|
||||||
namespace Web::Encoding {
|
namespace Web::Encoding {
|
||||||
|
|
||||||
// https://encoding.spec.whatwg.org/#textencoder
|
// https://encoding.spec.whatwg.org/#textencoder
|
||||||
class TextEncoder
|
class TextEncoder final : public Bindings::PlatformObject {
|
||||||
: public RefCounted<TextEncoder>
|
WEB_PLATFORM_OBJECT(TextEncoder, Bindings::PlatformObject);
|
||||||
, public Bindings::Wrappable {
|
|
||||||
public:
|
public:
|
||||||
using WrapperType = Bindings::TextEncoderWrapper;
|
static JS::NonnullGCPtr<TextEncoder> create_with_global_object(HTML::Window&);
|
||||||
|
|
||||||
static NonnullRefPtr<TextEncoder> create()
|
virtual ~TextEncoder() override;
|
||||||
{
|
|
||||||
return adopt_ref(*new TextEncoder());
|
|
||||||
}
|
|
||||||
|
|
||||||
static NonnullRefPtr<TextEncoder> create_with_global_object(HTML::Window&)
|
|
||||||
{
|
|
||||||
return TextEncoder::create();
|
|
||||||
}
|
|
||||||
|
|
||||||
JS::Uint8Array* encode(String const& input) const;
|
JS::Uint8Array* encode(String const& input) const;
|
||||||
|
|
||||||
|
@ -38,7 +30,9 @@ public:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// https://encoding.spec.whatwg.org/#dom-textencoder
|
// https://encoding.spec.whatwg.org/#dom-textencoder
|
||||||
TextEncoder() = default;
|
explicit TextEncoder(HTML::Window&);
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WRAPPER_HACK(TextEncoder, Web::Encoding)
|
||||||
|
|
|
@ -462,7 +462,6 @@ class RangePrototype;
|
||||||
class ResizeObserverWrapper;
|
class ResizeObserverWrapper;
|
||||||
class SelectionWrapper;
|
class SelectionWrapper;
|
||||||
class TextDecoderWrapper;
|
class TextDecoderWrapper;
|
||||||
class TextEncoderWrapper;
|
|
||||||
class URLSearchParamsIteratorWrapper;
|
class URLSearchParamsIteratorWrapper;
|
||||||
class URLSearchParamsWrapper;
|
class URLSearchParamsWrapper;
|
||||||
class URLWrapper;
|
class URLWrapper;
|
||||||
|
|
|
@ -52,7 +52,7 @@ libweb_js_wrapper(DOM/Text NO_INSTANCE)
|
||||||
libweb_js_wrapper(DOM/TreeWalker NO_INSTANCE)
|
libweb_js_wrapper(DOM/TreeWalker NO_INSTANCE)
|
||||||
libweb_js_wrapper(DOMParsing/XMLSerializer NO_INSTANCE)
|
libweb_js_wrapper(DOMParsing/XMLSerializer NO_INSTANCE)
|
||||||
libweb_js_wrapper(Encoding/TextDecoder)
|
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(Fetch/Headers ITERABLE)
|
||||||
libweb_js_wrapper(FileAPI/Blob)
|
libweb_js_wrapper(FileAPI/Blob)
|
||||||
libweb_js_wrapper(FileAPI/File)
|
libweb_js_wrapper(FileAPI/File)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue