mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 02:32:45 +00:00 
			
		
		
		
	 3bd14941c7
			
		
	
	
		3bd14941c7
		
	
	
	
	
		
			
			Change all the places that were including the deprecated parser, to include the new one instead, and then delete the old parser code. `ParentNode::query_selector[_all]()` now treat their input as a comma-separated list of selectors, instead of just one, and return elements that match any of the selectors in that list. This is according to these specs: - querySelector/querySelectorAll: https://dom.spec.whatwg.org/#ref-for-dom-parentnode-queryselector%E2%91%A0 - selector matching algorithm: https://www.w3.org/TR/selectors-4/#match-against-tree
		
			
				
	
	
		
			84 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020, Luke Wilde <lukew@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibWeb/CSS/Parser/Parser.h>
 | |
| #include <LibWeb/CSS/SelectorEngine.h>
 | |
| #include <LibWeb/DOM/ParentNode.h>
 | |
| #include <LibWeb/Dump.h>
 | |
| 
 | |
| namespace Web::DOM {
 | |
| 
 | |
| RefPtr<Element> ParentNode::query_selector(const StringView& selector_text)
 | |
| {
 | |
|     auto maybe_selectors = parse_selector(CSS::ParsingContext(*this), selector_text);
 | |
|     if (!maybe_selectors.has_value())
 | |
|         return {};
 | |
| 
 | |
|     auto selectors = maybe_selectors.value();
 | |
| 
 | |
|     for (auto& selector : selectors)
 | |
|         dump_selector(selector);
 | |
| 
 | |
|     RefPtr<Element> result;
 | |
|     for_each_in_inclusive_subtree_of_type<Element>([&](auto& element) {
 | |
|         for (auto& selector : selectors) {
 | |
|             if (SelectorEngine::matches(selector, element)) {
 | |
|                 result = element;
 | |
|                 return IterationDecision::Break;
 | |
|             }
 | |
|         }
 | |
|         return IterationDecision::Continue;
 | |
|     });
 | |
| 
 | |
|     return result;
 | |
| }
 | |
| 
 | |
| NonnullRefPtrVector<Element> ParentNode::query_selector_all(const StringView& selector_text)
 | |
| {
 | |
|     auto maybe_selectors = parse_selector(CSS::ParsingContext(*this), selector_text);
 | |
|     if (!maybe_selectors.has_value())
 | |
|         return {};
 | |
| 
 | |
|     auto selectors = maybe_selectors.value();
 | |
| 
 | |
|     for (auto& selector : selectors)
 | |
|         dump_selector(selector);
 | |
| 
 | |
|     NonnullRefPtrVector<Element> elements;
 | |
|     for_each_in_inclusive_subtree_of_type<Element>([&](auto& element) {
 | |
|         for (auto& selector : selectors) {
 | |
|             if (SelectorEngine::matches(selector, element)) {
 | |
|                 elements.append(element);
 | |
|             }
 | |
|         }
 | |
|         return IterationDecision::Continue;
 | |
|     });
 | |
| 
 | |
|     return elements;
 | |
| }
 | |
| 
 | |
| RefPtr<Element> ParentNode::first_element_child()
 | |
| {
 | |
|     return first_child_of_type<Element>();
 | |
| }
 | |
| 
 | |
| RefPtr<Element> ParentNode::last_element_child()
 | |
| {
 | |
|     return last_child_of_type<Element>();
 | |
| }
 | |
| 
 | |
| // https://dom.spec.whatwg.org/#dom-parentnode-childelementcount
 | |
| u32 ParentNode::child_element_count() const
 | |
| {
 | |
|     u32 count = 0;
 | |
|     for (auto* child = first_child(); child; child = child->next_sibling()) {
 | |
|         if (is<Element>(child))
 | |
|             ++count;
 | |
|     }
 | |
|     return count;
 | |
| }
 | |
| 
 | |
| }
 |