mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 08:07:44 +00:00
LibWeb: Abstract Range's members into AbstractRange
Range's member variables are stored in AbstractRange as per the spec, as they are also shared with StaticRange.
This commit is contained in:
parent
ed76b4238c
commit
a2acda5669
8 changed files with 86 additions and 42 deletions
|
@ -12,6 +12,8 @@
|
||||||
#include <LibWeb/Bindings/AbortControllerPrototype.h>
|
#include <LibWeb/Bindings/AbortControllerPrototype.h>
|
||||||
#include <LibWeb/Bindings/AbortSignalConstructor.h>
|
#include <LibWeb/Bindings/AbortSignalConstructor.h>
|
||||||
#include <LibWeb/Bindings/AbortSignalPrototype.h>
|
#include <LibWeb/Bindings/AbortSignalPrototype.h>
|
||||||
|
#include <LibWeb/Bindings/AbstractRangeConstructor.h>
|
||||||
|
#include <LibWeb/Bindings/AbstractRangePrototype.h>
|
||||||
#include <LibWeb/Bindings/AudioConstructor.h>
|
#include <LibWeb/Bindings/AudioConstructor.h>
|
||||||
#include <LibWeb/Bindings/CSSRuleConstructor.h>
|
#include <LibWeb/Bindings/CSSRuleConstructor.h>
|
||||||
#include <LibWeb/Bindings/CSSRuleListConstructor.h>
|
#include <LibWeb/Bindings/CSSRuleListConstructor.h>
|
||||||
|
@ -326,6 +328,7 @@
|
||||||
auto& vm = this->vm(); \
|
auto& vm = this->vm(); \
|
||||||
ADD_WINDOW_OBJECT_INTERFACE(AbortController) \
|
ADD_WINDOW_OBJECT_INTERFACE(AbortController) \
|
||||||
ADD_WINDOW_OBJECT_INTERFACE(AbortSignal) \
|
ADD_WINDOW_OBJECT_INTERFACE(AbortSignal) \
|
||||||
|
ADD_WINDOW_OBJECT_INTERFACE(AbstractRange) \
|
||||||
ADD_WINDOW_OBJECT_INTERFACE(Crypto) \
|
ADD_WINDOW_OBJECT_INTERFACE(Crypto) \
|
||||||
ADD_WINDOW_OBJECT_INTERFACE(CSSRule) \
|
ADD_WINDOW_OBJECT_INTERFACE(CSSRule) \
|
||||||
ADD_WINDOW_OBJECT_INTERFACE(CSSRuleList) \
|
ADD_WINDOW_OBJECT_INTERFACE(CSSRuleList) \
|
||||||
|
|
|
@ -411,6 +411,7 @@ libweb_js_wrapper(CSS/MediaQueryListEvent)
|
||||||
libweb_js_wrapper(CSS/Screen)
|
libweb_js_wrapper(CSS/Screen)
|
||||||
libweb_js_wrapper(CSS/StyleSheet)
|
libweb_js_wrapper(CSS/StyleSheet)
|
||||||
libweb_js_wrapper(CSS/StyleSheetList)
|
libweb_js_wrapper(CSS/StyleSheetList)
|
||||||
|
libweb_js_wrapper(DOM/AbstractRange)
|
||||||
libweb_js_wrapper(DOM/Attribute)
|
libweb_js_wrapper(DOM/Attribute)
|
||||||
libweb_js_wrapper(DOM/AbortController)
|
libweb_js_wrapper(DOM/AbortController)
|
||||||
libweb_js_wrapper(DOM/AbortSignal)
|
libweb_js_wrapper(DOM/AbortSignal)
|
||||||
|
|
53
Userland/Libraries/LibWeb/DOM/AbstractRange.h
Normal file
53
Userland/Libraries/LibWeb/DOM/AbstractRange.h
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2022, Luke Wilde <lukew@serenityos.org>
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <AK/RefCounted.h>
|
||||||
|
#include <LibWeb/Bindings/Wrappable.h>
|
||||||
|
|
||||||
|
namespace Web::DOM {
|
||||||
|
|
||||||
|
class AbstractRange
|
||||||
|
: public RefCounted<AbstractRange>
|
||||||
|
, public Bindings::Wrappable {
|
||||||
|
public:
|
||||||
|
using WrapperType = Bindings::AbstractRangeWrapper;
|
||||||
|
|
||||||
|
virtual ~AbstractRange() override = default;
|
||||||
|
|
||||||
|
Node* start_container() { return m_start_container; }
|
||||||
|
const Node* start_container() const { return m_start_container; }
|
||||||
|
unsigned start_offset() const { return m_start_offset; }
|
||||||
|
|
||||||
|
Node* end_container() { return m_end_container; }
|
||||||
|
const Node* end_container() const { return m_end_container; }
|
||||||
|
unsigned end_offset() const { return m_end_offset; }
|
||||||
|
|
||||||
|
// https://dom.spec.whatwg.org/#range-collapsed
|
||||||
|
bool collapsed() const
|
||||||
|
{
|
||||||
|
// A range is collapsed if its start node is its end node and its start offset is its end offset.
|
||||||
|
return start_container() == end_container() && start_offset() == end_offset();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
AbstractRange(Node& start_container, u32 start_offset, Node& end_container, u32 end_offset)
|
||||||
|
: m_start_container(start_container)
|
||||||
|
, m_start_offset(start_offset)
|
||||||
|
, m_end_container(end_container)
|
||||||
|
, m_end_offset(end_offset)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
NonnullRefPtr<Node> m_start_container;
|
||||||
|
u32 m_start_offset;
|
||||||
|
|
||||||
|
NonnullRefPtr<Node> m_end_container;
|
||||||
|
u32 m_end_offset;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
8
Userland/Libraries/LibWeb/DOM/AbstractRange.idl
Normal file
8
Userland/Libraries/LibWeb/DOM/AbstractRange.idl
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
[Exposed=Window]
|
||||||
|
interface AbstractRange {
|
||||||
|
readonly attribute Node startContainer;
|
||||||
|
readonly attribute unsigned long startOffset;
|
||||||
|
readonly attribute Node endContainer;
|
||||||
|
readonly attribute unsigned long endOffset;
|
||||||
|
readonly attribute boolean collapsed;
|
||||||
|
};
|
|
@ -1,5 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2020, the SerenityOS developers.
|
* Copyright (c) 2020, the SerenityOS developers.
|
||||||
|
* Copyright (c) 2022, Luke Wilde <lukew@serenityos.org>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
|
@ -21,10 +22,11 @@ NonnullRefPtr<Range> Range::create(Document& document)
|
||||||
return adopt_ref(*new Range(document));
|
return adopt_ref(*new Range(document));
|
||||||
}
|
}
|
||||||
|
|
||||||
NonnullRefPtr<Range> Range::create(Node& start_container, size_t start_offset, Node& end_container, size_t end_offset)
|
NonnullRefPtr<Range> Range::create(Node& start_container, u32 start_offset, Node& end_container, u32 end_offset)
|
||||||
{
|
{
|
||||||
return adopt_ref(*new Range(start_container, start_offset, end_container, end_offset));
|
return adopt_ref(*new Range(start_container, start_offset, end_container, end_offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
NonnullRefPtr<Range> Range::create_with_global_object(Bindings::WindowObject& window)
|
NonnullRefPtr<Range> Range::create_with_global_object(Bindings::WindowObject& window)
|
||||||
{
|
{
|
||||||
return Range::create(window.impl());
|
return Range::create(window.impl());
|
||||||
|
@ -35,11 +37,12 @@ Range::Range(Document& document)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
Range::Range(Node& start_container, size_t start_offset, Node& end_container, size_t end_offset)
|
Range::Range(Node& start_container, u32 start_offset, Node& end_container, u32 end_offset)
|
||||||
: m_start_container(start_container)
|
: AbstractRange(start_container, start_offset, end_container, end_offset)
|
||||||
, m_start_offset(start_offset)
|
{
|
||||||
, m_end_container(end_container)
|
}
|
||||||
, m_end_offset(end_offset)
|
|
||||||
|
Range::~Range()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,44 +1,29 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2020, the SerenityOS developers.
|
* Copyright (c) 2020, the SerenityOS developers.
|
||||||
|
* Copyright (c) 2022, Luke Wilde <lukew@serenityos.org>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <AK/RefCounted.h>
|
#include <LibWeb/DOM/AbstractRange.h>
|
||||||
#include <LibWeb/Bindings/WindowObject.h>
|
|
||||||
#include <LibWeb/Bindings/Wrappable.h>
|
|
||||||
#include <LibWeb/DOM/Node.h>
|
|
||||||
|
|
||||||
namespace Web::DOM {
|
namespace Web::DOM {
|
||||||
|
|
||||||
class Range final
|
class Range final : public AbstractRange {
|
||||||
: public RefCounted<Range>
|
|
||||||
, public Bindings::Wrappable {
|
|
||||||
public:
|
public:
|
||||||
using WrapperType = Bindings::RangeWrapper;
|
using WrapperType = Bindings::RangeWrapper;
|
||||||
|
|
||||||
|
virtual ~Range() override;
|
||||||
|
|
||||||
static NonnullRefPtr<Range> create(Document&);
|
static NonnullRefPtr<Range> create(Document&);
|
||||||
static NonnullRefPtr<Range> create(Window&);
|
static NonnullRefPtr<Range> create(Window&);
|
||||||
static NonnullRefPtr<Range> create(Node& start_container, size_t start_offset, Node& end_container, size_t end_offset);
|
static NonnullRefPtr<Range> create(Node& start_container, u32 start_offset, Node& end_container, u32 end_offset);
|
||||||
static NonnullRefPtr<Range> create_with_global_object(Bindings::WindowObject&);
|
static NonnullRefPtr<Range> create_with_global_object(Bindings::WindowObject&);
|
||||||
|
|
||||||
// FIXME: There are a ton of methods missing here.
|
// FIXME: There are a ton of methods missing here.
|
||||||
|
|
||||||
Node* start_container() { return m_start_container; }
|
|
||||||
const Node* start_container() const { return m_start_container; }
|
|
||||||
unsigned start_offset() const { return m_start_offset; }
|
|
||||||
|
|
||||||
Node* end_container() { return m_end_container; }
|
|
||||||
const Node* end_container() const { return m_end_container; }
|
|
||||||
unsigned end_offset() const { return m_end_offset; }
|
|
||||||
|
|
||||||
bool collapsed() const
|
|
||||||
{
|
|
||||||
return start_container() == end_container() && start_offset() == end_offset();
|
|
||||||
}
|
|
||||||
|
|
||||||
void set_start(Node& container, unsigned offset)
|
void set_start(Node& container, unsigned offset)
|
||||||
{
|
{
|
||||||
m_start_container = container;
|
m_start_container = container;
|
||||||
|
@ -60,13 +45,7 @@ public:
|
||||||
private:
|
private:
|
||||||
explicit Range(Document&);
|
explicit Range(Document&);
|
||||||
|
|
||||||
Range(Node& start_container, size_t start_offset, Node& end_container, size_t end_offset);
|
Range(Node& start_container, u32 start_offset, Node& end_container, u32 end_offset);
|
||||||
|
|
||||||
NonnullRefPtr<Node> m_start_container;
|
|
||||||
unsigned m_start_offset;
|
|
||||||
|
|
||||||
NonnullRefPtr<Node> m_end_container;
|
|
||||||
unsigned m_end_offset;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +1,13 @@
|
||||||
#import <DOM/Node.idl>
|
#import <DOM/Node.idl>
|
||||||
|
#import <DOM/AbstractRange.idl>
|
||||||
|
|
||||||
interface Range {
|
[Exposed=Window]
|
||||||
|
interface Range : AbstractRange {
|
||||||
|
|
||||||
constructor();
|
constructor();
|
||||||
|
|
||||||
readonly attribute boolean collapsed;
|
|
||||||
|
|
||||||
readonly attribute Node commonAncestorContainer;
|
readonly attribute Node commonAncestorContainer;
|
||||||
|
|
||||||
readonly attribute Node startContainer;
|
|
||||||
readonly attribute unsigned long startOffset;
|
|
||||||
readonly attribute Node endContainer;
|
|
||||||
readonly attribute unsigned long endOffset;
|
|
||||||
|
|
||||||
undefined setStart(Node node, unsigned long offset);
|
undefined setStart(Node node, unsigned long offset);
|
||||||
undefined setEnd(Node node, unsigned long offset);
|
undefined setEnd(Node node, unsigned long offset);
|
||||||
|
|
||||||
|
|
|
@ -86,6 +86,7 @@ class UnsetStyleValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace Web::DOM {
|
namespace Web::DOM {
|
||||||
|
class AbstractRange;
|
||||||
class AbortController;
|
class AbortController;
|
||||||
class AbortSignal;
|
class AbortSignal;
|
||||||
class Attribute;
|
class Attribute;
|
||||||
|
@ -347,6 +348,7 @@ class URLSearchParamsIterator;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace Web::Bindings {
|
namespace Web::Bindings {
|
||||||
|
class AbstractRangeWrapper;
|
||||||
class AbortControllerWrapper;
|
class AbortControllerWrapper;
|
||||||
class AbortSignalWrapper;
|
class AbortSignalWrapper;
|
||||||
class AttributeWrapper;
|
class AttributeWrapper;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue