mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-26 01:20:25 +00:00
f87041bf3a
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
93 lines
2.8 KiB
C++
93 lines
2.8 KiB
C++
/*
|
|
* Copyright (c) 2023, Andrew Kaster <akaster@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibGC/Heap.h>
|
|
#include <LibJS/Runtime/Realm.h>
|
|
#include <LibWeb/Bindings/Intrinsics.h>
|
|
#include <LibWeb/Bindings/NavigationDestinationPrototype.h>
|
|
#include <LibWeb/HTML/NavigationDestination.h>
|
|
#include <LibWeb/HTML/NavigationHistoryEntry.h>
|
|
|
|
namespace Web::HTML {
|
|
|
|
GC_DEFINE_ALLOCATOR(NavigationDestination);
|
|
|
|
GC::Ref<NavigationDestination> NavigationDestination::create(JS::Realm& realm)
|
|
{
|
|
return realm.create<NavigationDestination>(realm);
|
|
}
|
|
|
|
NavigationDestination::NavigationDestination(JS::Realm& realm)
|
|
: Bindings::PlatformObject(realm)
|
|
{
|
|
}
|
|
|
|
NavigationDestination::~NavigationDestination() = default;
|
|
|
|
void NavigationDestination::initialize(JS::Realm& realm)
|
|
{
|
|
Base::initialize(realm);
|
|
WEB_SET_PROTOTYPE_FOR_INTERFACE(NavigationDestination);
|
|
}
|
|
|
|
void NavigationDestination::visit_edges(JS::Cell::Visitor& visitor)
|
|
{
|
|
Base::visit_edges(visitor);
|
|
visitor.visit(m_entry);
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/nav-history-apis.html#dom-navigationdestination-url
|
|
WebIDL::ExceptionOr<String> NavigationDestination::url() const
|
|
{
|
|
// The url getter steps are to return this's URL, serialized.
|
|
return TRY_OR_THROW_OOM(vm(), String::from_byte_string(m_url.serialize()));
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/nav-history-apis.html#dom-navigationdestination-key
|
|
String NavigationDestination::key() const
|
|
{
|
|
// The key getter steps are:
|
|
|
|
// 1. If this's entry is null, then return the empty string.
|
|
// 2. Return this's entry's key.
|
|
return (m_entry == nullptr) ? String {} : m_entry->key();
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/nav-history-apis.html#dom-navigationdestination-id
|
|
String NavigationDestination::id() const
|
|
{
|
|
// The id getter steps are:
|
|
|
|
// 1. If this's entry is null, then return the empty string.
|
|
// 2. Return this's entry's ID.
|
|
return (m_entry == nullptr) ? String {} : m_entry->id();
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/nav-history-apis.html#dom-navigationdestination-index
|
|
i64 NavigationDestination::index() const
|
|
{
|
|
// The index getter steps are:
|
|
|
|
// 1. If this's entry is null, then return -1.
|
|
// 2. Return this's entry's index.
|
|
return (m_entry == nullptr) ? -1 : m_entry->index();
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/nav-history-apis.html#dom-navigationdestination-samedocument
|
|
bool NavigationDestination::same_document() const
|
|
{
|
|
// The sameDocument getter steps are to return this's is same document.
|
|
return m_is_same_document;
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/nav-history-apis.html#dom-navigationdestination-getstate
|
|
WebIDL::ExceptionOr<JS::Value> NavigationDestination::get_state()
|
|
{
|
|
// The getState() method steps are to return StructuredDeserialize(this's state).
|
|
return structured_deserialize(vm(), m_state, realm(), {});
|
|
}
|
|
|
|
}
|