mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-25 18:34:14 +00:00 
			
		
		
		
	 869abe0b21
			
		
	
	
		869abe0b21
		
	
	
	
	
		
			
			Previously we only matched against the first attribute with a given local name. What we actually want to do is look at each attribute with that local name in turn and only return false if none of them match. Also remove a hack for HTML elements in HTML documents, where we would refuse to match any namespaced attributes. This doesn't seem to be based on the spec, but we had regressions without it, until now. :^) Gets us 21 more WPT subtest passes.
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Tim Flynn <trflynn89@serenityos.org>
 | |
|  * Copyright (c) 2022, Andreas Kling <andreas@ladybird.org>
 | |
|  * Copyright (c) 2022, Alexander Narsudinov <a.narsudinov@gmail.com>
 | |
|  * Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibWeb/Bindings/PlatformObject.h>
 | |
| #include <LibWeb/Forward.h>
 | |
| #include <LibWeb/WebIDL/ExceptionOr.h>
 | |
| 
 | |
| namespace Web::DOM {
 | |
| 
 | |
| // https://dom.spec.whatwg.org/#interface-namednodemap
 | |
| class NamedNodeMap : public Bindings::PlatformObject {
 | |
|     WEB_PLATFORM_OBJECT(NamedNodeMap, Bindings::PlatformObject);
 | |
|     GC_DECLARE_ALLOCATOR(NamedNodeMap);
 | |
| 
 | |
| public:
 | |
|     [[nodiscard]] static GC::Ref<NamedNodeMap> create(Element&);
 | |
|     ~NamedNodeMap() = default;
 | |
| 
 | |
|     virtual Vector<FlyString> supported_property_names() const override;
 | |
|     virtual Optional<JS::Value> item_value(size_t index) const override;
 | |
|     virtual JS::Value named_item_value(FlyString const& name) const override;
 | |
| 
 | |
|     size_t length() const { return m_attributes.size(); }
 | |
|     bool is_empty() const { return m_attributes.is_empty(); }
 | |
| 
 | |
|     // Methods defined by the spec for JavaScript:
 | |
|     Attr const* item(u32 index) const;
 | |
|     Attr const* get_named_item(FlyString const& qualified_name) const;
 | |
|     Attr const* get_named_item_ns(Optional<FlyString> const& namespace_, FlyString const& local_name) const;
 | |
|     WebIDL::ExceptionOr<GC::Ptr<Attr>> set_named_item(Attr& attribute);
 | |
|     WebIDL::ExceptionOr<GC::Ptr<Attr>> set_named_item_ns(Attr& attribute);
 | |
|     WebIDL::ExceptionOr<Attr const*> remove_named_item(FlyString const& qualified_name);
 | |
|     WebIDL::ExceptionOr<Attr const*> remove_named_item_ns(Optional<FlyString> const& namespace_, FlyString const& local_name);
 | |
| 
 | |
|     // Methods defined by the spec for internal use:
 | |
|     Attr* get_attribute(FlyString const& qualified_name, size_t* item_index = nullptr);
 | |
|     Attr const* get_attribute(FlyString const& qualified_name, size_t* item_index = nullptr) const;
 | |
|     WebIDL::ExceptionOr<GC::Ptr<Attr>> set_attribute(Attr& attribute);
 | |
|     void replace_attribute(Attr& old_attribute, Attr& new_attribute, size_t old_attribute_index);
 | |
|     void append_attribute(Attr& attribute);
 | |
| 
 | |
|     Attr* get_attribute_ns(Optional<FlyString> const& namespace_, FlyString const& local_name, size_t* item_index = nullptr);
 | |
|     Attr const* get_attribute_ns(Optional<FlyString> const& namespace_, FlyString const& local_name, size_t* item_index = nullptr) const;
 | |
| 
 | |
|     Attr const* remove_attribute(FlyString const& qualified_name);
 | |
|     Attr const* remove_attribute_ns(Optional<FlyString> const& namespace_, FlyString const& local_name);
 | |
| 
 | |
|     WebIDL::ExceptionOr<GC::Ref<Attr>> remove_attribute_node(GC::Ref<Attr>);
 | |
| 
 | |
| private:
 | |
|     explicit NamedNodeMap(Element&);
 | |
| 
 | |
|     virtual void initialize(JS::Realm&) override;
 | |
|     virtual void visit_edges(Cell::Visitor&) override;
 | |
| 
 | |
|     Element& associated_element() { return *m_element; }
 | |
|     Element const& associated_element() const { return *m_element; }
 | |
| 
 | |
|     void remove_attribute_at_index(size_t attribute_index);
 | |
| 
 | |
|     GC::Ref<DOM::Element> m_element;
 | |
|     Vector<GC::Ref<Attr>> m_attributes;
 | |
| };
 | |
| 
 | |
| }
 |