mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-25 01:19:45 +00:00 
			
		
		
		
	Resulting in a massive rename across almost everywhere! Alongside the namespace change, we now have the following names: * JS::NonnullGCPtr -> GC::Ref * JS::GCPtr -> GC::Ptr * JS::HeapFunction -> GC::Function * JS::CellImpl -> GC::Cell * JS::Handle -> GC::Root
		
			
				
	
	
		
			80 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibWeb/Bindings/PlatformObject.h>
 | |
| #include <LibWeb/HTML/WindowOrWorkerGlobalScope.h>
 | |
| 
 | |
| namespace Web::PerformanceTimeline {
 | |
| 
 | |
| // https://w3c.github.io/performance-timeline/#dom-performanceobserverinit
 | |
| struct PerformanceObserverInit {
 | |
|     Optional<Vector<String>> entry_types;
 | |
|     Optional<String> type;
 | |
|     Optional<bool> buffered;
 | |
| };
 | |
| 
 | |
| // https://w3c.github.io/performance-timeline/#dom-performanceobserver
 | |
| class PerformanceObserver final : public Bindings::PlatformObject {
 | |
|     WEB_PLATFORM_OBJECT(PerformanceObserver, Bindings::PlatformObject);
 | |
|     GC_DECLARE_ALLOCATOR(PerformanceObserver);
 | |
| 
 | |
| public:
 | |
|     enum class ObserverType {
 | |
|         Undefined,
 | |
|         Single,
 | |
|         Multiple,
 | |
|     };
 | |
| 
 | |
|     static WebIDL::ExceptionOr<GC::Ref<PerformanceObserver>> construct_impl(JS::Realm&, GC::Ptr<WebIDL::CallbackType>);
 | |
|     virtual ~PerformanceObserver() override;
 | |
| 
 | |
|     WebIDL::ExceptionOr<void> observe(PerformanceObserverInit& options);
 | |
|     void disconnect();
 | |
|     Vector<GC::Root<PerformanceTimeline::PerformanceEntry>> take_records();
 | |
| 
 | |
|     bool requires_dropped_entries() const { return m_requires_dropped_entries; }
 | |
|     void unset_requires_dropped_entries(Badge<HTML::WindowOrWorkerGlobalScopeMixin>);
 | |
| 
 | |
|     Vector<PerformanceObserverInit> const& options_list() const { return m_options_list; }
 | |
| 
 | |
|     WebIDL::CallbackType& callback() { return *m_callback; }
 | |
| 
 | |
|     void append_to_observer_buffer(Badge<HTML::WindowOrWorkerGlobalScopeMixin>, GC::Ref<PerformanceTimeline::PerformanceEntry>);
 | |
| 
 | |
|     static GC::Ref<JS::Object> supported_entry_types(JS::VM&);
 | |
| 
 | |
| private:
 | |
|     PerformanceObserver(JS::Realm&, GC::Ptr<WebIDL::CallbackType>);
 | |
| 
 | |
|     virtual void initialize(JS::Realm&) override;
 | |
|     virtual void visit_edges(Cell::Visitor&) override;
 | |
| 
 | |
|     // https://w3c.github.io/performance-timeline/#dfn-observer-callback
 | |
|     // A PerformanceObserverCallback observer callback set on creation.
 | |
|     GC::Ptr<WebIDL::CallbackType> m_callback;
 | |
| 
 | |
|     // https://w3c.github.io/performance-timeline/#dfn-observer-buffer
 | |
|     // A PerformanceEntryList object called the observer buffer that is initially empty.
 | |
|     Vector<GC::Ref<PerformanceTimeline::PerformanceEntry>> m_observer_buffer;
 | |
| 
 | |
|     // https://w3c.github.io/performance-timeline/#dfn-observer-type
 | |
|     // A DOMString observer type which is initially "undefined".
 | |
|     ObserverType m_observer_type { ObserverType::Undefined };
 | |
| 
 | |
|     // https://w3c.github.io/performance-timeline/#dfn-requires-dropped-entries
 | |
|     // A boolean requires dropped entries which is initially set to false.
 | |
|     bool m_requires_dropped_entries { false };
 | |
| 
 | |
|     // https://w3c.github.io/performance-timeline/#dfn-options-list
 | |
|     // A registered performance observer is a struct consisting of an observer member (a PerformanceObserver object)
 | |
|     // and an options list member (a list of PerformanceObserverInit dictionaries).
 | |
|     // NOTE: This doesn't use a separate struct as methods such as disconnect() assume it can access an options list from `this`: a PerformanceObserver.
 | |
|     Vector<PerformanceObserverInit> m_options_list;
 | |
| };
 | |
| 
 | |
| }
 |