mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-22 07:30:19 +00:00
LibWeb: Make MediaList GC-allocated
This commit is contained in:
parent
0176d42f49
commit
cfdb8f2a8e
Notes:
sideshowbarker
2024-07-17 07:28:43 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/cfdb8f2a8e Pull-request: https://github.com/SerenityOS/serenity/pull/14816 Reviewed-by: https://github.com/ADKaster Reviewed-by: https://github.com/linusg ✅
9 changed files with 58 additions and 35 deletions
|
@ -36,10 +36,9 @@ public:
|
|||
|
||||
protected:
|
||||
explicit CSSGroupingRule(Bindings::WindowObject&, CSSRuleList&);
|
||||
|
||||
private:
|
||||
virtual void visit_edges(Cell::Visitor&) override;
|
||||
|
||||
private:
|
||||
CSSRuleList& m_rules;
|
||||
};
|
||||
|
||||
|
|
|
@ -11,26 +11,32 @@
|
|||
|
||||
namespace Web::CSS {
|
||||
|
||||
CSSMediaRule* CSSMediaRule::create(Bindings::WindowObject& window_object, NonnullRefPtr<MediaList>&& media_queries, CSSRuleList& rules)
|
||||
CSSMediaRule* CSSMediaRule::create(Bindings::WindowObject& window_object, MediaList& media_queries, CSSRuleList& rules)
|
||||
{
|
||||
return window_object.heap().allocate<CSSMediaRule>(window_object.realm(), window_object, move(media_queries), rules);
|
||||
return window_object.heap().allocate<CSSMediaRule>(window_object.realm(), window_object, media_queries, rules);
|
||||
}
|
||||
|
||||
CSSMediaRule::CSSMediaRule(Bindings::WindowObject& window_object, NonnullRefPtr<MediaList>&& media, CSSRuleList& rules)
|
||||
CSSMediaRule::CSSMediaRule(Bindings::WindowObject& window_object, MediaList& media, CSSRuleList& rules)
|
||||
: CSSConditionRule(window_object, rules)
|
||||
, m_media(move(media))
|
||||
, m_media(media)
|
||||
{
|
||||
set_prototype(&window_object.ensure_web_prototype<Bindings::CSSMediaRulePrototype>("CSSMediaRule"));
|
||||
}
|
||||
|
||||
void CSSMediaRule::visit_edges(Cell::Visitor& visitor)
|
||||
{
|
||||
Base::visit_edges(visitor);
|
||||
visitor.visit(&m_media);
|
||||
}
|
||||
|
||||
String CSSMediaRule::condition_text() const
|
||||
{
|
||||
return m_media->media_text();
|
||||
return m_media.media_text();
|
||||
}
|
||||
|
||||
void CSSMediaRule::set_condition_text(String text)
|
||||
{
|
||||
m_media->set_media_text(text);
|
||||
m_media.set_media_text(text);
|
||||
}
|
||||
|
||||
// https://www.w3.org/TR/cssom-1/#serialize-a-css-rule
|
||||
|
|
|
@ -22,8 +22,8 @@ class CSSMediaRule final : public CSSConditionRule {
|
|||
public:
|
||||
CSSMediaRule& impl() { return *this; }
|
||||
|
||||
static CSSMediaRule* create(Bindings::WindowObject&, NonnullRefPtr<MediaList>&& media_queries, CSSRuleList&);
|
||||
explicit CSSMediaRule(Bindings::WindowObject&, NonnullRefPtr<MediaList>&&, CSSRuleList&);
|
||||
static CSSMediaRule* create(Bindings::WindowObject&, MediaList& media_queries, CSSRuleList&);
|
||||
explicit CSSMediaRule(Bindings::WindowObject&, MediaList&, CSSRuleList&);
|
||||
|
||||
virtual ~CSSMediaRule() = default;
|
||||
|
||||
|
@ -31,16 +31,17 @@ public:
|
|||
|
||||
virtual String condition_text() const override;
|
||||
virtual void set_condition_text(String) override;
|
||||
virtual bool condition_matches() const override { return m_media->matches(); }
|
||||
virtual bool condition_matches() const override { return m_media.matches(); }
|
||||
|
||||
NonnullRefPtr<MediaList> const& media() const { return m_media; }
|
||||
MediaList* media() const { return &m_media; }
|
||||
|
||||
bool evaluate(HTML::Window const& window) { return m_media->evaluate(window); }
|
||||
bool evaluate(HTML::Window const& window) { return m_media.evaluate(window); }
|
||||
|
||||
private:
|
||||
virtual void visit_edges(Cell::Visitor&) override;
|
||||
virtual String serialized() const override;
|
||||
|
||||
NonnullRefPtr<MediaList> m_media;
|
||||
MediaList& m_media;
|
||||
};
|
||||
|
||||
template<>
|
||||
|
|
|
@ -1,16 +1,25 @@
|
|||
/*
|
||||
* Copyright (c) 2021, Sam Atkins <atkinssj@serenityos.org>
|
||||
* Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibWeb/Bindings/MediaListPrototype.h>
|
||||
#include <LibWeb/Bindings/WindowObject.h>
|
||||
#include <LibWeb/CSS/MediaList.h>
|
||||
#include <LibWeb/CSS/Parser/Parser.h>
|
||||
|
||||
namespace Web::CSS {
|
||||
|
||||
MediaList::MediaList(NonnullRefPtrVector<MediaQuery>&& media)
|
||||
: m_media(move(media))
|
||||
MediaList* MediaList::create(Bindings::WindowObject& window_object, NonnullRefPtrVector<MediaQuery>&& media)
|
||||
{
|
||||
return window_object.heap().allocate<MediaList>(window_object.realm(), window_object, move(media));
|
||||
}
|
||||
|
||||
MediaList::MediaList(Bindings::WindowObject& window_object, NonnullRefPtrVector<MediaQuery>&& media)
|
||||
: Bindings::LegacyPlatformObject(window_object.ensure_web_prototype<Bindings::MediaListPrototype>("MediaList"))
|
||||
, m_media(move(media))
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -83,4 +92,11 @@ bool MediaList::matches() const
|
|||
return false;
|
||||
}
|
||||
|
||||
JS::Value MediaList::item_value(size_t index) const
|
||||
{
|
||||
if (index >= m_media.size())
|
||||
return JS::js_undefined();
|
||||
return JS::js_string(vm(), m_media[index].to_string());
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
/*
|
||||
* Copyright (c) 2021-2022, Sam Atkins <atkinssj@serenityos.org>
|
||||
* Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
@ -8,44 +9,45 @@
|
|||
|
||||
#include <AK/NonnullRefPtrVector.h>
|
||||
#include <AK/Optional.h>
|
||||
#include <AK/RefCounted.h>
|
||||
#include <LibWeb/Bindings/Wrappable.h>
|
||||
#include <LibJS/Runtime/Object.h>
|
||||
#include <LibWeb/Bindings/LegacyPlatformObject.h>
|
||||
#include <LibWeb/CSS/MediaQuery.h>
|
||||
|
||||
namespace Web::CSS {
|
||||
|
||||
// https://www.w3.org/TR/cssom-1/#the-medialist-interface
|
||||
class MediaList final
|
||||
: public RefCounted<MediaList>
|
||||
, public Bindings::Wrappable
|
||||
, public Weakable<MediaList> {
|
||||
class MediaList final : public Bindings::LegacyPlatformObject {
|
||||
AK_MAKE_NONCOPYABLE(MediaList);
|
||||
AK_MAKE_NONMOVABLE(MediaList);
|
||||
JS_OBJECT(MediaList, Bindings::LegacyPlatformObject);
|
||||
|
||||
public:
|
||||
using WrapperType = Bindings::MediaListWrapper;
|
||||
|
||||
static NonnullRefPtr<MediaList> create(NonnullRefPtrVector<MediaQuery>&& media)
|
||||
{
|
||||
return adopt_ref(*new MediaList(move(media)));
|
||||
}
|
||||
static MediaList* create(Bindings::WindowObject&, NonnullRefPtrVector<MediaQuery>&& media);
|
||||
explicit MediaList(Bindings::WindowObject&, NonnullRefPtrVector<MediaQuery>&&);
|
||||
~MediaList() = default;
|
||||
|
||||
MediaList& impl() { return *this; }
|
||||
|
||||
String media_text() const;
|
||||
void set_media_text(String const&);
|
||||
size_t length() const { return m_media.size(); }
|
||||
bool is_supported_property_index(u32 index) const;
|
||||
String item(u32 index) const;
|
||||
void append_medium(String);
|
||||
void delete_medium(String);
|
||||
|
||||
virtual bool is_supported_property_index(u32 index) const override;
|
||||
virtual JS::Value item_value(size_t index) const override;
|
||||
|
||||
bool evaluate(HTML::Window const&);
|
||||
bool matches() const;
|
||||
|
||||
private:
|
||||
explicit MediaList(NonnullRefPtrVector<MediaQuery>&&);
|
||||
|
||||
NonnullRefPtrVector<MediaQuery> m_media;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
namespace Web::Bindings {
|
||||
inline JS::Object* wrap(JS::Realm&, Web::CSS::MediaList& object) { return &object; }
|
||||
using MediaListWrapper = Web::CSS::MediaList;
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
[Exposed=Window]
|
||||
[Exposed=Window, NoInstanceWrapper]
|
||||
interface MediaList {
|
||||
[LegacyNullToEmptyString] stringifier attribute CSSOMString mediaText;
|
||||
readonly attribute unsigned long length;
|
||||
|
|
|
@ -2648,7 +2648,7 @@ CSSRule* Parser::convert_to_rule(NonnullRefPtr<Rule> rule)
|
|||
child_rules.append(child_rule);
|
||||
}
|
||||
auto* rule_list = CSSRuleList::create(m_context.window_object(), move(child_rules));
|
||||
return CSSMediaRule::create(m_context.window_object(), MediaList::create(move(media_query_list)), *rule_list);
|
||||
return CSSMediaRule::create(m_context.window_object(), *MediaList::create(m_context.window_object(), move(media_query_list)), *rule_list);
|
||||
|
||||
} else if (rule->at_rule_name().equals_ignoring_case("supports"sv)) {
|
||||
|
||||
|
|
|
@ -559,7 +559,6 @@ class ImageDataWrapper;
|
|||
class IntersectionObserverWrapper;
|
||||
class KeyboardEventWrapper;
|
||||
class LocationObject;
|
||||
class MediaListWrapper;
|
||||
class MediaQueryListEventWrapper;
|
||||
class MediaQueryListWrapper;
|
||||
class MessageChannelWrapper;
|
||||
|
|
|
@ -14,7 +14,7 @@ libweb_js_wrapper(CSS/CSSStyleDeclaration NO_INSTANCE)
|
|||
libweb_js_wrapper(CSS/CSSStyleRule NO_INSTANCE)
|
||||
libweb_js_wrapper(CSS/CSSStyleSheet NO_INSTANCE)
|
||||
libweb_js_wrapper(CSS/CSSSupportsRule NO_INSTANCE)
|
||||
libweb_js_wrapper(CSS/MediaList)
|
||||
libweb_js_wrapper(CSS/MediaList NO_INSTANCE)
|
||||
libweb_js_wrapper(CSS/MediaQueryList)
|
||||
libweb_js_wrapper(CSS/MediaQueryListEvent)
|
||||
libweb_js_wrapper(CSS/Screen)
|
||||
|
|
Loading…
Reference in a new issue