LibHTML: Replace StyleProperties::create(StyleProperties) with clone()

This commit is contained in:
Matrix89 2020-01-05 16:54:38 +01:00 committed by Andreas Kling
parent 2dd35916e5
commit c2e1dd67c9
Notes: sideshowbarker 2024-07-19 10:20:14 +09:00
3 changed files with 26 additions and 8 deletions

View file

@ -3,6 +3,25 @@
#include <LibHTML/FontCache.h>
#include <ctype.h>
StyleProperties::StyleProperties()
{
}
StyleProperties::StyleProperties(const StyleProperties& other)
: m_property_values(*new HashMap(other.m_property_values))
{
if (other.m_font) {
m_font = other.m_font->clone();
} else {
m_font = nullptr;
}
}
NonnullRefPtr<StyleProperties> StyleProperties::clone() const
{
return adopt(*new StyleProperties(*this));
}
void StyleProperties::set_property(CSS::PropertyID id, NonnullRefPtr<StyleValue> value)
{
m_property_values.set((unsigned)id, move(value));

View file

@ -9,14 +9,13 @@ class Color;
class StyleProperties : public RefCounted<StyleProperties> {
public:
StyleProperties();
explicit StyleProperties(const StyleProperties&);
static NonnullRefPtr<StyleProperties> create() { return adopt(*new StyleProperties); }
static NonnullRefPtr<StyleProperties> create(const StyleProperties& properties) {
auto style_properties = new StyleProperties();
properties.for_each_property([&](auto property_id, auto& property_value) {
style_properties->set_property(property_id, property_value);
});
return adopt(*style_properties);
}
NonnullRefPtr<StyleProperties> clone() const;
template<typename Callback>
inline void for_each_property(Callback callback) const

View file

@ -165,7 +165,7 @@ void Element::recompute_style()
RefPtr<StyleProperties> Element::computed_style()
{
auto properties = StyleProperties::create(*m_resolved_style);
auto properties = m_resolved_style->clone();
if (layout_node() && layout_node()->has_style()) {
CSS::PropertyID box_model_metrics[] = {
CSS::PropertyID::MarginTop,