/* * Copyright (c) 2023, Tim Flynn * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include namespace Web::HTML { JS_DEFINE_ALLOCATOR(TrackEvent); JS::NonnullGCPtr TrackEvent::create(JS::Realm& realm, FlyString const& event_name, TrackEventInit event_init) { return realm.heap().allocate(realm, realm, event_name, move(event_init)); } WebIDL::ExceptionOr> TrackEvent::construct_impl(JS::Realm& realm, FlyString const& event_name, TrackEventInit event_init) { return create(realm, event_name, move(event_init)); } TrackEvent::TrackEvent(JS::Realm& realm, FlyString const& event_name, TrackEventInit event_init) : DOM::Event(realm, event_name, event_init) , m_track(move(event_init.track)) { } void TrackEvent::initialize(JS::Realm& realm) { Base::initialize(realm); WEB_SET_PROTOTYPE_FOR_INTERFACE(TrackEvent); } Variant, JS::Handle> TrackEvent::track() const { // FIXME: This is a bit awkward. When creating a nullable union, our IDL generator creates a type of // Optional>, using an empty Optional to represent null. But when retrieving the // attribute, it expects a type of Variant, using Empty to represent null. if (!m_track.has_value()) return Empty {}; return *m_track; } }