mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-22 15:40:19 +00:00
LibWeb/HTML: Port Window.atob() to IDL
This commit is contained in:
parent
192f5e61f6
commit
6dd1934ed8
Notes:
sideshowbarker
2024-07-17 02:57:43 +09:00
Author: https://github.com/linusg Commit: https://github.com/SerenityOS/serenity/commit/6dd1934ed8 Pull-request: https://github.com/SerenityOS/serenity/pull/17752 Reviewed-by: https://github.com/awesomekling
3 changed files with 2 additions and 31 deletions
|
@ -1063,7 +1063,6 @@ WebIDL::ExceptionOr<void> Window::initialize_web_interfaces(Badge<WindowEnvironm
|
||||||
define_native_function(realm, "clearTimeout", clear_timeout, 1, attr);
|
define_native_function(realm, "clearTimeout", clear_timeout, 1, attr);
|
||||||
define_native_function(realm, "requestAnimationFrame", request_animation_frame, 1, attr);
|
define_native_function(realm, "requestAnimationFrame", request_animation_frame, 1, attr);
|
||||||
define_native_function(realm, "cancelAnimationFrame", cancel_animation_frame, 1, attr);
|
define_native_function(realm, "cancelAnimationFrame", cancel_animation_frame, 1, attr);
|
||||||
define_native_function(realm, "atob", atob, 1, attr);
|
|
||||||
define_native_function(realm, "focus", focus, 0, attr);
|
define_native_function(realm, "focus", focus, 0, attr);
|
||||||
|
|
||||||
define_native_function(realm, "queueMicrotask", queue_microtask, 1, attr);
|
define_native_function(realm, "queueMicrotask", queue_microtask, 1, attr);
|
||||||
|
@ -1472,35 +1471,6 @@ JS_DEFINE_NATIVE_FUNCTION(Window::cancel_idle_callback)
|
||||||
return JS::js_undefined();
|
return JS::js_undefined();
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://html.spec.whatwg.org/multipage/webappapis.html#dom-atob-dev
|
|
||||||
JS_DEFINE_NATIVE_FUNCTION(Window::atob)
|
|
||||||
{
|
|
||||||
if (!vm.argument_count())
|
|
||||||
return vm.throw_completion<JS::TypeError>(JS::ErrorType::BadArgCountOne, "atob");
|
|
||||||
auto deprecated_string = TRY(vm.argument(0).to_deprecated_string(vm));
|
|
||||||
auto string = String::from_utf8(deprecated_string).release_value_but_fixme_should_propagate_errors();
|
|
||||||
|
|
||||||
// must throw an "InvalidCharacterError" DOMException if data contains any character whose code point is greater than U+00FF
|
|
||||||
for (auto code_point : string.code_points()) {
|
|
||||||
if (code_point > 0x00FF)
|
|
||||||
return throw_completion(WebIDL::InvalidCharacterError::create(*vm.current_realm(), "Data contains characters outside the range U+0000 and U+00FF"));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Otherwise, the user agent must convert data to a byte sequence whose nth byte is the eight-bit representation of the nth code point of data
|
|
||||||
// and then must apply forgiving-base64 encode to that byte sequence and return the result.
|
|
||||||
auto decoded = Infra::decode_forgiving_base64(StringView(deprecated_string));
|
|
||||||
if (decoded.is_error())
|
|
||||||
return vm.throw_completion<JS::TypeError>(JS::ErrorType::InvalidFormat, "Base64");
|
|
||||||
|
|
||||||
// The bytes object might contain bytes greater than 128, encode them in UTF8
|
|
||||||
// NOTE: Any 8-bit encoding -> utf-8 decoder will work for this
|
|
||||||
auto text_decoder = TextCodec::decoder_for("windows-1252"sv);
|
|
||||||
VERIFY(text_decoder.has_value());
|
|
||||||
auto text = TRY_OR_THROW_OOM(vm, text_decoder->to_utf8(decoded.release_value()));
|
|
||||||
|
|
||||||
return JS::PrimitiveString::create(vm, text);
|
|
||||||
}
|
|
||||||
|
|
||||||
// https://html.spec.whatwg.org/multipage/interaction.html#dom-window-focus
|
// https://html.spec.whatwg.org/multipage/interaction.html#dom-window-focus
|
||||||
JS_DEFINE_NATIVE_FUNCTION(Window::focus)
|
JS_DEFINE_NATIVE_FUNCTION(Window::focus)
|
||||||
{
|
{
|
||||||
|
|
|
@ -46,6 +46,7 @@ public:
|
||||||
|
|
||||||
~Window();
|
~Window();
|
||||||
|
|
||||||
|
using WindowOrWorkerGlobalScopeMixin::atob;
|
||||||
using WindowOrWorkerGlobalScopeMixin::btoa;
|
using WindowOrWorkerGlobalScopeMixin::btoa;
|
||||||
|
|
||||||
// ^DOM::EventTarget
|
// ^DOM::EventTarget
|
||||||
|
@ -266,7 +267,6 @@ private:
|
||||||
JS_DECLARE_NATIVE_FUNCTION(clear_timeout);
|
JS_DECLARE_NATIVE_FUNCTION(clear_timeout);
|
||||||
JS_DECLARE_NATIVE_FUNCTION(request_animation_frame);
|
JS_DECLARE_NATIVE_FUNCTION(request_animation_frame);
|
||||||
JS_DECLARE_NATIVE_FUNCTION(cancel_animation_frame);
|
JS_DECLARE_NATIVE_FUNCTION(cancel_animation_frame);
|
||||||
JS_DECLARE_NATIVE_FUNCTION(atob);
|
|
||||||
JS_DECLARE_NATIVE_FUNCTION(focus);
|
JS_DECLARE_NATIVE_FUNCTION(focus);
|
||||||
|
|
||||||
JS_DECLARE_NATIVE_FUNCTION(get_computed_style);
|
JS_DECLARE_NATIVE_FUNCTION(get_computed_style);
|
||||||
|
|
|
@ -40,6 +40,7 @@ interface Window : EventTarget {
|
||||||
[Replaceable] readonly attribute USVString origin;
|
[Replaceable] readonly attribute USVString origin;
|
||||||
readonly attribute boolean isSecureContext;
|
readonly attribute boolean isSecureContext;
|
||||||
DOMString btoa(DOMString data);
|
DOMString btoa(DOMString data);
|
||||||
|
ByteString atob(DOMString data);
|
||||||
};
|
};
|
||||||
Window includes GlobalEventHandlers;
|
Window includes GlobalEventHandlers;
|
||||||
Window includes WindowEventHandlers;
|
Window includes WindowEventHandlers;
|
||||||
|
|
Loading…
Reference in a new issue