mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-31 13:20:59 +00:00 
			
		
		
		
	 c5c1a8fcc7
			
		
	
	
		c5c1a8fcc7
		
	
	
	
	
		
			
			This removes some ambiguity about what the return value should be if the index is out of range. Previously, we would sometimes return a JS null, and other times a JS undefined. It will also let us fold together the checks for whether an index is a supported property index, followed by getting the value just afterwards.
		
			
				
	
	
		
			78 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021-2022, Sam Atkins <atkinssj@serenityos.org>
 | |
|  * Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
 | |
|  * Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Function.h>
 | |
| #include <AK/Iterator.h>
 | |
| #include <AK/RefPtr.h>
 | |
| #include <LibWeb/Bindings/PlatformObject.h>
 | |
| #include <LibWeb/CSS/CSSRule.h>
 | |
| #include <LibWeb/Forward.h>
 | |
| #include <LibWeb/WebIDL/ExceptionOr.h>
 | |
| 
 | |
| namespace Web::CSS {
 | |
| 
 | |
| // https://www.w3.org/TR/cssom/#the-cssrulelist-interface
 | |
| class CSSRuleList : public Bindings::PlatformObject {
 | |
|     WEB_PLATFORM_OBJECT(CSSRuleList, Bindings::PlatformObject);
 | |
|     JS_DECLARE_ALLOCATOR(CSSRuleList);
 | |
| 
 | |
| public:
 | |
|     [[nodiscard]] static JS::NonnullGCPtr<CSSRuleList> create(JS::Realm&, JS::MarkedVector<CSSRule*> const&);
 | |
|     [[nodiscard]] static JS::NonnullGCPtr<CSSRuleList> create_empty(JS::Realm&);
 | |
| 
 | |
|     ~CSSRuleList() = default;
 | |
| 
 | |
|     CSSRule const* item(size_t index) const
 | |
|     {
 | |
|         if (index >= length())
 | |
|             return nullptr;
 | |
|         return m_rules[index];
 | |
|     }
 | |
| 
 | |
|     CSSRule* item(size_t index)
 | |
|     {
 | |
|         if (index >= length())
 | |
|             return nullptr;
 | |
|         return m_rules[index];
 | |
|     }
 | |
| 
 | |
|     size_t length() const { return m_rules.size(); }
 | |
| 
 | |
|     auto begin() const { return m_rules.begin(); }
 | |
|     auto begin() { return m_rules.begin(); }
 | |
| 
 | |
|     auto end() const { return m_rules.end(); }
 | |
|     auto end() { return m_rules.end(); }
 | |
| 
 | |
|     virtual bool is_supported_property_index(u32 index) const override;
 | |
|     virtual Optional<JS::Value> item_value(size_t index) const override;
 | |
| 
 | |
|     WebIDL::ExceptionOr<void> remove_a_css_rule(u32 index);
 | |
|     WebIDL::ExceptionOr<unsigned> insert_a_css_rule(Variant<StringView, CSSRule*>, u32 index);
 | |
| 
 | |
|     void for_each_effective_style_rule(Function<void(CSSStyleRule const&)> const& callback) const;
 | |
|     // Returns whether the match state of any media queries changed after evaluation.
 | |
|     bool evaluate_media_queries(HTML::Window const&);
 | |
|     void for_each_effective_keyframes_at_rule(Function<void(CSSKeyframesRule const&)> const& callback) const;
 | |
| 
 | |
|     void set_rules(Badge<CSSStyleSheet>, Vector<JS::NonnullGCPtr<CSSRule>> rules) { m_rules = move(rules); }
 | |
| 
 | |
|     Function<void()> on_change;
 | |
| 
 | |
| private:
 | |
|     explicit CSSRuleList(JS::Realm&);
 | |
| 
 | |
|     virtual void initialize(JS::Realm&) override;
 | |
|     virtual void visit_edges(Cell::Visitor&) override;
 | |
| 
 | |
|     Vector<JS::NonnullGCPtr<CSSRule>> m_rules;
 | |
| };
 | |
| 
 | |
| }
 |