mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-31 21:30:58 +00:00 
			
		
		
		
	 f87041bf3a
			
		
	
	
		f87041bf3a
		
	
	
	
	
		
			
			Resulting in a massive rename across almost everywhere! Alongside the namespace change, we now have the following names: * JS::NonnullGCPtr -> GC::Ref * JS::GCPtr -> GC::Ptr * JS::HeapFunction -> GC::Function * JS::CellImpl -> GC::Cell * JS::Handle -> GC::Root
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021-2023, Sam Atkins <atkinssj@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibWeb/Bindings/CSSSupportsRulePrototype.h>
 | |
| #include <LibWeb/Bindings/Intrinsics.h>
 | |
| #include <LibWeb/CSS/CSSSupportsRule.h>
 | |
| #include <LibWeb/CSS/Parser/Parser.h>
 | |
| 
 | |
| namespace Web::CSS {
 | |
| 
 | |
| GC_DEFINE_ALLOCATOR(CSSSupportsRule);
 | |
| 
 | |
| GC::Ref<CSSSupportsRule> CSSSupportsRule::create(JS::Realm& realm, NonnullRefPtr<Supports>&& supports, CSSRuleList& rules)
 | |
| {
 | |
|     return realm.create<CSSSupportsRule>(realm, move(supports), rules);
 | |
| }
 | |
| 
 | |
| CSSSupportsRule::CSSSupportsRule(JS::Realm& realm, NonnullRefPtr<Supports>&& supports, CSSRuleList& rules)
 | |
|     : CSSConditionRule(realm, rules, Type::Supports)
 | |
|     , m_supports(move(supports))
 | |
| {
 | |
| }
 | |
| 
 | |
| void CSSSupportsRule::initialize(JS::Realm& realm)
 | |
| {
 | |
|     Base::initialize(realm);
 | |
|     WEB_SET_PROTOTYPE_FOR_INTERFACE(CSSSupportsRule);
 | |
| }
 | |
| 
 | |
| String CSSSupportsRule::condition_text() const
 | |
| {
 | |
|     return m_supports->to_string();
 | |
| }
 | |
| 
 | |
| // https://www.w3.org/TR/cssom-1/#serialize-a-css-rule
 | |
| String CSSSupportsRule::serialized() const
 | |
| {
 | |
|     // Note: The spec doesn't cover this yet, so I'm roughly following the spec for the @media rule.
 | |
|     // It should be pretty close!
 | |
| 
 | |
|     StringBuilder builder;
 | |
| 
 | |
|     builder.append("@supports "sv);
 | |
|     builder.append(condition_text());
 | |
|     builder.append(" {\n"sv);
 | |
|     for (size_t i = 0; i < css_rules().length(); i++) {
 | |
|         auto rule = css_rules().item(i);
 | |
|         if (i != 0)
 | |
|             builder.append("\n"sv);
 | |
|         builder.append("  "sv);
 | |
|         builder.append(rule->css_text());
 | |
|     }
 | |
|     builder.append("\n}"sv);
 | |
| 
 | |
|     return MUST(builder.to_string());
 | |
| }
 | |
| 
 | |
| }
 |