mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-22 16:09:23 +00:00 
			
		
		
		
	This reverts 0e3487b9ab.
Back when I made that change, I thought we could make our StyleValue
classes match the typed-om definitions directly. However, they have
different requirements. Typed-om types need to be mutable and GCed,
whereas StyleValues are immutable and ideally wouldn't require a JS VM.
While I was already making such a cataclysmic change, I've moved it into
the StyleValues directory, because it *not* being there has bothered me
for a long time. 😅
		
	
			
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2025, Sam Atkins <sam@ladybird.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Optional.h>
 | |
| #include <LibGfx/Color.h>
 | |
| #include <LibGfx/Cursor.h>
 | |
| #include <LibWeb/CSS/CalculatedOr.h>
 | |
| #include <LibWeb/CSS/Length.h>
 | |
| #include <LibWeb/CSS/StyleValues/StyleValue.h>
 | |
| #include <LibWeb/Forward.h>
 | |
| 
 | |
| namespace Web::CSS {
 | |
| 
 | |
| class CursorStyleValue final : public StyleValueWithDefaultOperators<CursorStyleValue> {
 | |
| public:
 | |
|     static ValueComparingNonnullRefPtr<CursorStyleValue const> create(ValueComparingNonnullRefPtr<AbstractImageStyleValue const> image, Optional<NumberOrCalculated> x, Optional<NumberOrCalculated> y)
 | |
|     {
 | |
|         VERIFY(x.has_value() == y.has_value());
 | |
|         return adopt_ref(*new (nothrow) CursorStyleValue(move(image), move(x), move(y)));
 | |
|     }
 | |
|     virtual ~CursorStyleValue() override = default;
 | |
| 
 | |
|     ValueComparingNonnullRefPtr<AbstractImageStyleValue const> image() const { return m_properties.image; }
 | |
|     Optional<NumberOrCalculated> const& x() const { return m_properties.x; }
 | |
|     Optional<NumberOrCalculated> const& y() const { return m_properties.y; }
 | |
| 
 | |
|     Optional<Gfx::ImageCursor> make_image_cursor(Layout::NodeWithStyle const&) const;
 | |
| 
 | |
|     virtual String to_string(SerializationMode) const override;
 | |
| 
 | |
|     virtual ValueComparingNonnullRefPtr<StyleValue const> absolutized(CSSPixelRect const& viewport_rect, Length::FontMetrics const& font_metrics, Length::FontMetrics const& root_font_metrics) const override;
 | |
| 
 | |
|     bool properties_equal(CursorStyleValue const& other) const { return m_properties == other.m_properties; }
 | |
| 
 | |
| private:
 | |
|     CursorStyleValue(ValueComparingNonnullRefPtr<AbstractImageStyleValue const> image,
 | |
|         Optional<NumberOrCalculated> x,
 | |
|         Optional<NumberOrCalculated> y)
 | |
|         : StyleValueWithDefaultOperators(Type::Cursor)
 | |
|         , m_properties { .image = move(image), .x = move(x), .y = move(y) }
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     struct Properties {
 | |
|         ValueComparingNonnullRefPtr<AbstractImageStyleValue const> image;
 | |
|         Optional<NumberOrCalculated> x;
 | |
|         Optional<NumberOrCalculated> y;
 | |
|         bool operator==(Properties const&) const = default;
 | |
|     } m_properties;
 | |
| 
 | |
|     // Data that can affect the bitmap rendering.
 | |
|     struct CacheKey {
 | |
|         Length::ResolutionContext length_resolution_context;
 | |
|         Gfx::Color current_color;
 | |
|         bool operator==(CacheKey const&) const = default;
 | |
|     };
 | |
|     mutable Optional<CacheKey> m_cache_key;
 | |
|     mutable Optional<Gfx::ShareableBitmap> m_cached_bitmap;
 | |
| };
 | |
| 
 | |
| }
 |