mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 06:38:10 +00:00
LibWeb/HTML: Port Window.performance to IDL
This commit is contained in:
parent
95ce5735ce
commit
7de9179a6d
5 changed files with 25 additions and 39 deletions
|
@ -2710,6 +2710,7 @@ using namespace Web::DOMParsing;
|
||||||
using namespace Web::Fetch;
|
using namespace Web::Fetch;
|
||||||
using namespace Web::FileAPI;
|
using namespace Web::FileAPI;
|
||||||
using namespace Web::Geometry;
|
using namespace Web::Geometry;
|
||||||
|
using namespace Web::HighResolutionTime;
|
||||||
using namespace Web::HTML;
|
using namespace Web::HTML;
|
||||||
using namespace Web::IntersectionObserver;
|
using namespace Web::IntersectionObserver;
|
||||||
using namespace Web::RequestIdleCallback;
|
using namespace Web::RequestIdleCallback;
|
||||||
|
@ -2929,6 +2930,7 @@ using namespace Web::DOMParsing;
|
||||||
using namespace Web::Fetch;
|
using namespace Web::Fetch;
|
||||||
using namespace Web::FileAPI;
|
using namespace Web::FileAPI;
|
||||||
using namespace Web::Geometry;
|
using namespace Web::Geometry;
|
||||||
|
using namespace Web::HighResolutionTime;
|
||||||
using namespace Web::HTML;
|
using namespace Web::HTML;
|
||||||
using namespace Web::IntersectionObserver;
|
using namespace Web::IntersectionObserver;
|
||||||
using namespace Web::NavigationTiming;
|
using namespace Web::NavigationTiming;
|
||||||
|
@ -3056,6 +3058,7 @@ using namespace Web::DOMParsing;
|
||||||
using namespace Web::Fetch;
|
using namespace Web::Fetch;
|
||||||
using namespace Web::FileAPI;
|
using namespace Web::FileAPI;
|
||||||
using namespace Web::Geometry;
|
using namespace Web::Geometry;
|
||||||
|
using namespace Web::HighResolutionTime;
|
||||||
using namespace Web::HTML;
|
using namespace Web::HTML;
|
||||||
using namespace Web::IntersectionObserver;
|
using namespace Web::IntersectionObserver;
|
||||||
using namespace Web::NavigationTiming;
|
using namespace Web::NavigationTiming;
|
||||||
|
@ -3185,6 +3188,7 @@ using namespace Web::DOMParsing;
|
||||||
using namespace Web::Fetch;
|
using namespace Web::Fetch;
|
||||||
using namespace Web::FileAPI;
|
using namespace Web::FileAPI;
|
||||||
using namespace Web::Geometry;
|
using namespace Web::Geometry;
|
||||||
|
using namespace Web::HighResolutionTime;
|
||||||
using namespace Web::HTML;
|
using namespace Web::HTML;
|
||||||
using namespace Web::IntersectionObserver;
|
using namespace Web::IntersectionObserver;
|
||||||
using namespace Web::NavigationTiming;
|
using namespace Web::NavigationTiming;
|
||||||
|
|
|
@ -187,8 +187,9 @@ void EventLoop::process()
|
||||||
// FIXME: 12. For each fully active Document in docs, if the user agent detects that the backing storage associated with a CanvasRenderingContext2D or an OffscreenCanvasRenderingContext2D, context, has been lost, then it must run the context lost steps for each such context:
|
// FIXME: 12. For each fully active Document in docs, if the user agent detects that the backing storage associated with a CanvasRenderingContext2D or an OffscreenCanvasRenderingContext2D, context, has been lost, then it must run the context lost steps for each such context:
|
||||||
|
|
||||||
// FIXME: 13. For each fully active Document in docs, run the animation frame callbacks for that Document, passing in now as the timestamp.
|
// FIXME: 13. For each fully active Document in docs, run the animation frame callbacks for that Document, passing in now as the timestamp.
|
||||||
|
auto now = HighResolutionTime::unsafe_shared_current_time();
|
||||||
for_each_fully_active_document_in_docs([&](DOM::Document& document) {
|
for_each_fully_active_document_in_docs([&](DOM::Document& document) {
|
||||||
run_animation_frame_callbacks(document, document.window().performance().now());
|
run_animation_frame_callbacks(document, now);
|
||||||
});
|
});
|
||||||
|
|
||||||
// FIXME: 14. For each fully active Document in docs, run the update intersection observations steps for that Document, passing in now as the timestamp. [INTERSECTIONOBSERVER]
|
// FIXME: 14. For each fully active Document in docs, run the update intersection observations steps for that Document, passing in now as the timestamp. [INTERSECTIONOBSERVER]
|
||||||
|
|
|
@ -118,13 +118,6 @@ void Window::visit_edges(JS::Cell::Visitor& visitor)
|
||||||
|
|
||||||
Window::~Window() = default;
|
Window::~Window() = default;
|
||||||
|
|
||||||
HighResolutionTime::Performance& Window::performance()
|
|
||||||
{
|
|
||||||
if (!m_performance)
|
|
||||||
m_performance = heap().allocate<HighResolutionTime::Performance>(realm(), *this).release_allocated_value_but_fixme_should_propagate_errors();
|
|
||||||
return *m_performance;
|
|
||||||
}
|
|
||||||
|
|
||||||
CSS::Screen& Window::screen()
|
CSS::Screen& Window::screen()
|
||||||
{
|
{
|
||||||
if (!m_screen)
|
if (!m_screen)
|
||||||
|
@ -553,9 +546,11 @@ i32 Window::run_timer_initialization_steps(TimerHandler handler, i32 timeout, JS
|
||||||
// https://html.spec.whatwg.org/multipage/imagebitmap-and-animations.html#run-the-animation-frame-callbacks
|
// https://html.spec.whatwg.org/multipage/imagebitmap-and-animations.html#run-the-animation-frame-callbacks
|
||||||
i32 Window::request_animation_frame_impl(WebIDL::CallbackType& js_callback)
|
i32 Window::request_animation_frame_impl(WebIDL::CallbackType& js_callback)
|
||||||
{
|
{
|
||||||
return m_animation_frame_callback_driver.add([this, js_callback = JS::make_handle(js_callback)](auto) {
|
// FIXME: `now` is supposed to be passed in
|
||||||
|
auto now = HighResolutionTime::unsafe_shared_current_time();
|
||||||
|
return m_animation_frame_callback_driver.add([this, now, js_callback = JS::make_handle(js_callback)](auto) {
|
||||||
// 3. Invoke callback, passing now as the only argument,
|
// 3. Invoke callback, passing now as the only argument,
|
||||||
auto result = WebIDL::invoke_callback(*js_callback, {}, JS::Value(performance().now()));
|
auto result = WebIDL::invoke_callback(*js_callback, {}, JS::Value(now));
|
||||||
|
|
||||||
// and if an exception is thrown, report the exception.
|
// and if an exception is thrown, report the exception.
|
||||||
if (result.is_error())
|
if (result.is_error())
|
||||||
|
@ -1050,7 +1045,6 @@ WebIDL::ExceptionOr<void> Window::initialize_web_interfaces(Badge<WindowEnvironm
|
||||||
MUST_OR_THROW_OOM(Bindings::WindowGlobalMixin::initialize(realm, *this));
|
MUST_OR_THROW_OOM(Bindings::WindowGlobalMixin::initialize(realm, *this));
|
||||||
|
|
||||||
// FIXME: These should be native accessors, not properties
|
// FIXME: These should be native accessors, not properties
|
||||||
define_native_accessor(realm, "performance", performance_getter, performance_setter, JS::Attribute::Enumerable | JS::Attribute::Configurable);
|
|
||||||
define_native_accessor(realm, "crypto", crypto_getter, {}, JS::Attribute::Enumerable);
|
define_native_accessor(realm, "crypto", crypto_getter, {}, JS::Attribute::Enumerable);
|
||||||
define_native_accessor(realm, "screen", screen_getter, screen_setter, JS::Attribute::Enumerable | JS::Attribute::Configurable);
|
define_native_accessor(realm, "screen", screen_getter, screen_setter, JS::Attribute::Enumerable | JS::Attribute::Configurable);
|
||||||
define_native_accessor(realm, "innerWidth", inner_width_getter, {}, JS::Attribute::Enumerable);
|
define_native_accessor(realm, "innerWidth", inner_width_getter, {}, JS::Attribute::Enumerable);
|
||||||
|
@ -1338,6 +1332,14 @@ Variant<JS::Handle<DOM::Event>, JS::Value> Window::event() const
|
||||||
return JS::js_undefined();
|
return JS::js_undefined();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// https://w3c.github.io/hr-time/#dom-windoworworkerglobalscope-performance
|
||||||
|
WebIDL::ExceptionOr<JS::NonnullGCPtr<HighResolutionTime::Performance>> Window::performance()
|
||||||
|
{
|
||||||
|
if (!m_performance)
|
||||||
|
m_performance = MUST_OR_THROW_OOM(heap().allocate<HighResolutionTime::Performance>(realm(), *this));
|
||||||
|
return JS::NonnullGCPtr { *m_performance };
|
||||||
|
}
|
||||||
|
|
||||||
static JS::ThrowCompletionOr<TimerHandler> make_timer_handler(JS::VM& vm, JS::Value handler)
|
static JS::ThrowCompletionOr<TimerHandler> make_timer_handler(JS::VM& vm, JS::Value handler)
|
||||||
{
|
{
|
||||||
if (handler.is_function())
|
if (handler.is_function())
|
||||||
|
@ -1511,29 +1513,6 @@ size_t Window::document_tree_child_browsing_context_count() const
|
||||||
return this_browsing_context->document_tree_child_browsing_context_count();
|
return this_browsing_context->document_tree_child_browsing_context_count();
|
||||||
}
|
}
|
||||||
|
|
||||||
JS_DEFINE_NATIVE_FUNCTION(Window::performance_getter)
|
|
||||||
{
|
|
||||||
auto* impl = TRY(impl_from(vm));
|
|
||||||
return &impl->performance();
|
|
||||||
}
|
|
||||||
|
|
||||||
JS_DEFINE_NATIVE_FUNCTION(Window::performance_setter)
|
|
||||||
{
|
|
||||||
// https://webidl.spec.whatwg.org/#dfn-attribute-setter
|
|
||||||
// 4.1. If no arguments were passed, then throw a TypeError.
|
|
||||||
if (vm.argument_count() == 0)
|
|
||||||
return vm.throw_completion<JS::TypeError>(JS::ErrorType::BadArgCountOne, "set performance");
|
|
||||||
|
|
||||||
auto* impl = TRY(impl_from(vm));
|
|
||||||
|
|
||||||
// 5. If attribute is declared with the [Replaceable] extended attribute, then:
|
|
||||||
// 1. Perform ? CreateDataProperty(esValue, id, V).
|
|
||||||
TRY(impl->create_data_property("performance", vm.argument(0)));
|
|
||||||
|
|
||||||
// 2. Return undefined.
|
|
||||||
return JS::js_undefined();
|
|
||||||
}
|
|
||||||
|
|
||||||
JS_DEFINE_NATIVE_FUNCTION(Window::screen_getter)
|
JS_DEFINE_NATIVE_FUNCTION(Window::screen_getter)
|
||||||
{
|
{
|
||||||
auto* impl = TRY(impl_from(vm));
|
auto* impl = TRY(impl_from(vm));
|
||||||
|
|
|
@ -96,8 +96,6 @@ public:
|
||||||
|
|
||||||
void deallocate_timer_id(Badge<Timer>, i32);
|
void deallocate_timer_id(Badge<Timer>, i32);
|
||||||
|
|
||||||
HighResolutionTime::Performance& performance();
|
|
||||||
|
|
||||||
Crypto::Crypto& crypto() { return *m_crypto; }
|
Crypto::Crypto& crypto() { return *m_crypto; }
|
||||||
|
|
||||||
CSS::Screen& screen();
|
CSS::Screen& screen();
|
||||||
|
@ -169,6 +167,8 @@ public:
|
||||||
|
|
||||||
Variant<JS::Handle<DOM::Event>, JS::Value> event() const;
|
Variant<JS::Handle<DOM::Event>, JS::Value> event() const;
|
||||||
|
|
||||||
|
WebIDL::ExceptionOr<JS::NonnullGCPtr<HighResolutionTime::Performance>> performance();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit Window(JS::Realm&);
|
explicit Window(JS::Realm&);
|
||||||
|
|
||||||
|
@ -231,9 +231,6 @@ public:
|
||||||
private:
|
private:
|
||||||
JS_DECLARE_NATIVE_FUNCTION(location_setter);
|
JS_DECLARE_NATIVE_FUNCTION(location_setter);
|
||||||
|
|
||||||
JS_DECLARE_NATIVE_FUNCTION(performance_getter);
|
|
||||||
JS_DECLARE_NATIVE_FUNCTION(performance_setter);
|
|
||||||
|
|
||||||
JS_DECLARE_NATIVE_FUNCTION(screen_getter);
|
JS_DECLARE_NATIVE_FUNCTION(screen_getter);
|
||||||
JS_DECLARE_NATIVE_FUNCTION(screen_setter);
|
JS_DECLARE_NATIVE_FUNCTION(screen_setter);
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#import <DOM/Document.idl>
|
#import <DOM/Document.idl>
|
||||||
#import <DOM/EventHandler.idl>
|
#import <DOM/EventHandler.idl>
|
||||||
#import <DOM/EventTarget.idl>
|
#import <DOM/EventTarget.idl>
|
||||||
|
#import <HighResolutionTime/Performance.idl>
|
||||||
#import <HTML/Navigator.idl>
|
#import <HTML/Navigator.idl>
|
||||||
#import <HTML/WindowOrWorkerGlobalScope.idl>
|
#import <HTML/WindowOrWorkerGlobalScope.idl>
|
||||||
|
|
||||||
|
@ -39,6 +40,10 @@ interface Window : EventTarget {
|
||||||
|
|
||||||
// https://dom.spec.whatwg.org/#interface-window-extensions
|
// https://dom.spec.whatwg.org/#interface-window-extensions
|
||||||
[Replaceable] readonly attribute (Event or undefined) event; // legacy
|
[Replaceable] readonly attribute (Event or undefined) event; // legacy
|
||||||
|
|
||||||
|
// FIXME: Everything from here on should be shared through WindowOrWorkerGlobalScope
|
||||||
|
// https://w3c.github.io/hr-time/#the-performance-attribute
|
||||||
|
[Replaceable] readonly attribute Performance performance;
|
||||||
};
|
};
|
||||||
Window includes GlobalEventHandlers;
|
Window includes GlobalEventHandlers;
|
||||||
Window includes WindowEventHandlers;
|
Window includes WindowEventHandlers;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue