mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-08-02 06:09:08 +00:00
Everywhere: Hoist the Libraries folder to the top-level
This commit is contained in:
parent
950e819ee7
commit
93712b24bf
Notes:
github-actions[bot]
2024-11-10 11:51:52 +00:00
Author: https://github.com/trflynn89
Commit: 93712b24bf
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/2256
Reviewed-by: https://github.com/sideshowbarker
4547 changed files with 104 additions and 113 deletions
48
Libraries/LibWeb/HTML/TrackEvent.cpp
Normal file
48
Libraries/LibWeb/HTML/TrackEvent.cpp
Normal file
|
@ -0,0 +1,48 @@
|
|||
/*
|
||||
* 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_DEFINE_ALLOCATOR(TrackEvent);
|
||||
|
||||
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);
|
||||
WEB_SET_PROTOTYPE_FOR_INTERFACE(TrackEvent);
|
||||
}
|
||||
|
||||
Variant<Empty, JS::Handle<VideoTrack>, JS::Handle<AudioTrack>, JS::Handle<TextTrack>> 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;
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue