12345678910111213141516171819202122232425262728293031323334353637383940414243444546 |
- /*
- * Copyright (c) 2023, Tim Flynn <trflynn89@serenityos.org>
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #include <LibWeb/Bindings/Intrinsics.h>
- #include <LibWeb/Bindings/TrackEventPrototype.h>
- #include <LibWeb/HTML/TrackEvent.h>
- namespace Web::HTML {
- JS::NonnullGCPtr<TrackEvent> TrackEvent::create(JS::Realm& realm, FlyString const& event_name, TrackEventInit event_init)
- {
- return realm.heap().allocate<TrackEvent>(realm, realm, event_name, move(event_init));
- }
- WebIDL::ExceptionOr<JS::NonnullGCPtr<TrackEvent>> 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);
- set_prototype(&Bindings::ensure_web_prototype<Bindings::TrackEventPrototype>(realm, "TrackEvent"));
- }
- Variant<Empty, JS::Handle<VideoTrack>, JS::Handle<AudioTrack>> TrackEvent::track() const
- {
- // FIXME: This is a bit awkward. When creating a nullable union, our IDL generator creates a type of
- // Optional<Variant<...>>, using an empty Optional to represent null. But when retrieving the
- // attribute, it expects a type of Variant<Empty, ...>, using Empty to represent null.
- if (!m_track.has_value())
- return Empty {};
- return *m_track;
- }
- }
|