LibHTML: Use NonnullRefPtrVector in LibHTML.

This commit is contained in:
Andreas Kling 2019-06-27 12:16:20 +02:00
parent 48108ec474
commit 7cc9ce8380
5 changed files with 15 additions and 15 deletions

View file

@ -1,6 +1,6 @@
#include <LibHTML/CSS/StyleRule.h>
StyleRule::StyleRule(Vector<Selector>&& selectors, Vector<NonnullRefPtr<StyleDeclaration>>&& declarations)
StyleRule::StyleRule(Vector<Selector>&& selectors, NonnullRefPtrVector<StyleDeclaration>&& declarations)
: m_selectors(move(selectors))
, m_declarations(move(declarations))
{

View file

@ -1,12 +1,12 @@
#pragma once
#include <AK/Vector.h>
#include <AK/NonnullRefPtrVector.h>
#include <LibHTML/CSS/Selector.h>
#include <LibHTML/CSS/StyleDeclaration.h>
class StyleRule : public RefCounted<StyleRule> {
public:
static NonnullRefPtr<StyleRule> create(Vector<Selector>&& selectors, Vector<NonnullRefPtr<StyleDeclaration>>&& declarations)
static NonnullRefPtr<StyleRule> create(Vector<Selector>&& selectors, NonnullRefPtrVector<StyleDeclaration>&& declarations)
{
return adopt(*new StyleRule(move(selectors), move(declarations)));
}
@ -14,18 +14,18 @@ public:
~StyleRule();
const Vector<Selector>& selectors() const { return m_selectors; }
const Vector<NonnullRefPtr<StyleDeclaration>>& declarations() const { return m_declarations; }
const NonnullRefPtrVector<StyleDeclaration>& declarations() const { return m_declarations; }
template<typename C>
void for_each_declaration(C callback) const
{
for (auto& declaration : m_declarations)
callback(*declaration);
callback(declaration);
}
private:
StyleRule(Vector<Selector>&&, Vector<NonnullRefPtr<StyleDeclaration>>&&);
StyleRule(Vector<Selector>&&, NonnullRefPtrVector<StyleDeclaration>&&);
Vector<Selector> m_selectors;
Vector<NonnullRefPtr<StyleDeclaration>> m_declarations;
NonnullRefPtrVector<StyleDeclaration> m_declarations;
};

View file

@ -1,6 +1,6 @@
#include <LibHTML/CSS/StyleSheet.h>
StyleSheet::StyleSheet(Vector<NonnullRefPtr<StyleRule>>&& rules)
StyleSheet::StyleSheet(NonnullRefPtrVector<StyleRule>&& rules)
: m_rules(move(rules))
{
}

View file

@ -1,21 +1,21 @@
#pragma once
#include <AK/Vector.h>
#include <AK/NonnullRefPtrVector.h>
#include <LibHTML/CSS/StyleRule.h>
class StyleSheet : public RefCounted<StyleSheet> {
public:
static NonnullRefPtr<StyleSheet> create(Vector<NonnullRefPtr<StyleRule>>&& rules)
static NonnullRefPtr<StyleSheet> create(NonnullRefPtrVector<StyleRule>&& rules)
{
return adopt(*new StyleSheet(move(rules)));
}
~StyleSheet();
const Vector<NonnullRefPtr<StyleRule>>& rules() const { return m_rules; }
const NonnullRefPtrVector<StyleRule>& rules() const { return m_rules; }
private:
explicit StyleSheet(Vector<NonnullRefPtr<StyleRule>>&&);
explicit StyleSheet(NonnullRefPtrVector<StyleRule>&&);
Vector<NonnullRefPtr<StyleRule>> m_rules;
NonnullRefPtrVector<StyleRule> m_rules;
};

View file

@ -73,7 +73,7 @@ void dump_sheet(const StyleSheet& sheet)
for (auto& rule : sheet.rules()) {
printf("Rule:\n");
for (auto& selector : rule->selectors()) {
for (auto& selector : rule.selectors()) {
printf(" Selector:\n");
for (auto& component : selector.components()) {
const char* type_description = "Unknown";
@ -95,7 +95,7 @@ void dump_sheet(const StyleSheet& sheet)
}
}
printf(" Declarations:\n");
rule->for_each_declaration([](auto& declaration) {
rule.for_each_declaration([](auto& declaration) {
printf(" '%s': '%s'\n", declaration.property_name().characters(), declaration.value().to_string().characters());
});
}