2020-12-06 19:51:55 +01:00
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2020, the SerenityOS developers.
|
2022-01-30 23:35:51 +00:00
|
|
|
|
* Copyright (c) 2022, Luke Wilde <lukew@serenityos.org>
|
2020-12-06 19:51:55 +01:00
|
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-12-06 19:51:55 +01:00
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <LibWeb/DOM/Document.h>
|
|
|
|
|
#include <LibWeb/DOM/Node.h>
|
|
|
|
|
#include <LibWeb/DOM/Range.h>
|
2020-12-06 22:09:24 +01:00
|
|
|
|
#include <LibWeb/DOM/Window.h>
|
2020-12-06 19:51:55 +01:00
|
|
|
|
|
|
|
|
|
namespace Web::DOM {
|
|
|
|
|
|
2021-02-21 23:41:54 +01:00
|
|
|
|
NonnullRefPtr<Range> Range::create(Window& window)
|
|
|
|
|
{
|
2021-09-09 13:55:31 +02:00
|
|
|
|
return Range::create(window.associated_document());
|
2021-02-21 23:41:54 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NonnullRefPtr<Range> Range::create(Document& document)
|
|
|
|
|
{
|
2021-04-23 16:46:57 +02:00
|
|
|
|
return adopt_ref(*new Range(document));
|
2021-02-21 23:41:54 +01:00
|
|
|
|
}
|
|
|
|
|
|
2022-01-30 23:35:51 +00:00
|
|
|
|
NonnullRefPtr<Range> Range::create(Node& start_container, u32 start_offset, Node& end_container, u32 end_offset)
|
2021-02-21 23:41:54 +01:00
|
|
|
|
{
|
2021-04-23 16:46:57 +02:00
|
|
|
|
return adopt_ref(*new Range(start_container, start_offset, end_container, end_offset));
|
2021-02-21 23:41:54 +01:00
|
|
|
|
}
|
2022-01-30 23:35:51 +00:00
|
|
|
|
|
2021-02-21 23:41:54 +01:00
|
|
|
|
NonnullRefPtr<Range> Range::create_with_global_object(Bindings::WindowObject& window)
|
|
|
|
|
{
|
|
|
|
|
return Range::create(window.impl());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Range::Range(Document& document)
|
|
|
|
|
: Range(document, 0, document, 0)
|
2020-12-06 19:51:55 +01:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-30 23:35:51 +00:00
|
|
|
|
Range::Range(Node& start_container, u32 start_offset, Node& end_container, u32 end_offset)
|
|
|
|
|
: AbstractRange(start_container, start_offset, end_container, end_offset)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Range::~Range()
|
2020-12-06 19:51:55 +01:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NonnullRefPtr<Range> Range::clone_range() const
|
|
|
|
|
{
|
2021-04-23 16:46:57 +02:00
|
|
|
|
return adopt_ref(*new Range(const_cast<Node&>(*m_start_container), m_start_offset, const_cast<Node&>(*m_end_container), m_end_offset));
|
2020-12-06 19:51:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NonnullRefPtr<Range> Range::inverted() const
|
|
|
|
|
{
|
2021-04-23 16:46:57 +02:00
|
|
|
|
return adopt_ref(*new Range(const_cast<Node&>(*m_end_container), m_end_offset, const_cast<Node&>(*m_start_container), m_start_offset));
|
2020-12-06 19:51:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NonnullRefPtr<Range> Range::normalized() const
|
|
|
|
|
{
|
|
|
|
|
if (m_start_container.ptr() == m_end_container.ptr()) {
|
|
|
|
|
if (m_start_offset <= m_end_offset)
|
|
|
|
|
return clone_range();
|
|
|
|
|
|
|
|
|
|
return inverted();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (m_start_container->is_before(m_end_container))
|
|
|
|
|
return clone_range();
|
|
|
|
|
|
|
|
|
|
return inverted();
|
|
|
|
|
}
|
|
|
|
|
|
2022-02-25 20:45:03 +01:00
|
|
|
|
// https://dom.spec.whatwg.org/#dom-range-commonancestorcontainer
|
|
|
|
|
NonnullRefPtr<Node> Range::common_ancestor_container() const
|
|
|
|
|
{
|
|
|
|
|
// 1. Let container be start node.
|
|
|
|
|
auto container = m_start_container;
|
|
|
|
|
|
|
|
|
|
// 2. While container is not an inclusive ancestor of end node, let container be container’s parent.
|
|
|
|
|
while (!container->is_inclusive_ancestor_of(m_end_container)) {
|
|
|
|
|
VERIFY(container->parent());
|
|
|
|
|
container = *container->parent();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 3. Return container.
|
|
|
|
|
return container;
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-06 19:51:55 +01:00
|
|
|
|
}
|