summaryrefslogtreecommitdiff
path: root/Source/WebCore/rendering/style/ContentData.h
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
commit1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch)
tree46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/rendering/style/ContentData.h
parent32761a6cee1d0dee366b885b7b9c777e67885688 (diff)
downloadWebKitGtk-tarball-master.tar.gz
Diffstat (limited to 'Source/WebCore/rendering/style/ContentData.h')
-rw-r--r--Source/WebCore/rendering/style/ContentData.h189
1 files changed, 119 insertions, 70 deletions
diff --git a/Source/WebCore/rendering/style/ContentData.h b/Source/WebCore/rendering/style/ContentData.h
index 4d1b9717a..9e97c0235 100644
--- a/Source/WebCore/rendering/style/ContentData.h
+++ b/Source/WebCore/rendering/style/ContentData.h
@@ -2,7 +2,7 @@
* Copyright (C) 2000 Lars Knoll (knoll@kde.org)
* (C) 2000 Antti Koivisto (koivisto@kde.org)
* (C) 2000 Dirk Mueller (mueller@kde.org)
- * Copyright (C) 2003, 2005, 2006, 2007, 2008, 2010 Apple Inc. All rights reserved.
+ * Copyright (C) 2003-2017 Apple Inc. All rights reserved.
* Copyright (C) 2006 Graham Dennis (graham.dennis@gmail.com)
*
* This library is free software; you can redistribute it and/or
@@ -22,13 +22,12 @@
*
*/
-#ifndef ContentData_h
-#define ContentData_h
+#pragma once
#include "CounterContent.h"
#include "StyleImage.h"
#include "RenderPtr.h"
-#include <wtf/OwnPtr.h>
+#include <wtf/TypeCasts.h>
namespace WebCore {
@@ -39,149 +38,191 @@ class RenderStyle;
class ContentData {
WTF_MAKE_FAST_ALLOCATED;
public:
+ enum Type {
+ CounterDataType,
+ ImageDataType,
+ QuoteDataType,
+ TextDataType
+ };
virtual ~ContentData() { }
- virtual bool isCounter() const { return false; }
- virtual bool isImage() const { return false; }
- virtual bool isQuote() const { return false; }
- virtual bool isText() const { return false; }
+ Type type() const { return m_type; }
+
+ bool isCounter() const { return type() == CounterDataType; }
+ bool isImage() const { return type() == ImageDataType; }
+ bool isQuote() const { return type() == QuoteDataType; }
+ bool isText() const { return type() == TextDataType; }
virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const = 0;
std::unique_ptr<ContentData> clone() const;
ContentData* next() const { return m_next.get(); }
- void setNext(std::unique_ptr<ContentData> next) { m_next = std::move(next); }
+ void setNext(std::unique_ptr<ContentData> next) { m_next = WTFMove(next); }
void setAltText(const String& alt) { m_altText = alt; }
const String& altText() const { return m_altText; }
-
- virtual bool equals(const ContentData&) const = 0;
+
+protected:
+ explicit ContentData(Type type)
+ : m_type(type)
+ {
+ }
private:
virtual std::unique_ptr<ContentData> cloneInternal() const = 0;
std::unique_ptr<ContentData> m_next;
String m_altText;
+ Type m_type;
};
class ImageContentData final : public ContentData {
public:
- explicit ImageContentData(PassRefPtr<StyleImage> image)
- : m_image(image)
+ explicit ImageContentData(Ref<StyleImage>&& image)
+ : ContentData(ImageDataType)
+ , m_image(WTFMove(image))
{
}
- const StyleImage* image() const { return m_image.get(); }
- StyleImage* image() { return m_image.get(); }
- void setImage(PassRefPtr<StyleImage> image) { m_image = image; }
-
- virtual bool isImage() const override { return true; }
- virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
-
- virtual bool equals(const ContentData& data) const override
+ const StyleImage& image() const { return m_image.get(); }
+ void setImage(Ref<StyleImage>&& image)
{
- if (!data.isImage())
- return false;
- return *static_cast<const ImageContentData&>(data).image() == *image();
+ m_image = WTFMove(image);
}
private:
- virtual std::unique_ptr<ContentData> cloneInternal() const override
+ RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const final;
+ std::unique_ptr<ContentData> cloneInternal() const final
{
- RefPtr<StyleImage> image = const_cast<StyleImage*>(this->image());
-
- return std::make_unique<ImageContentData>(image.release());
+ auto image = std::make_unique<ImageContentData>(m_image.copyRef());
+ image->setAltText(altText());
+ return WTFMove(image);
}
- RefPtr<StyleImage> m_image;
+ Ref<StyleImage> m_image;
};
+inline bool operator==(const ImageContentData& a, const ImageContentData& b)
+{
+ return &a.image() == &b.image();
+}
+
+inline bool operator!=(const ImageContentData& a, const ImageContentData& b)
+{
+ return !(a == b);
+}
+
class TextContentData final : public ContentData {
public:
explicit TextContentData(const String& text)
- : m_text(text)
+ : ContentData(TextDataType)
+ , m_text(text)
{
}
const String& text() const { return m_text; }
void setText(const String& text) { m_text = text; }
- virtual bool isText() const override { return true; }
- virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
-
- virtual bool equals(const ContentData& data) const override
- {
- if (!data.isText())
- return false;
- return static_cast<const TextContentData&>(data).text() == text();
- }
-
private:
- virtual std::unique_ptr<ContentData> cloneInternal() const override { return std::make_unique<TextContentData>(text()); }
+ RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const final;
+ std::unique_ptr<ContentData> cloneInternal() const final { return std::make_unique<TextContentData>(m_text); }
String m_text;
};
+inline bool operator==(const TextContentData& a, const TextContentData& b)
+{
+ return a.text() == b.text();
+}
+
+inline bool operator!=(const TextContentData& a, const TextContentData& b)
+{
+ return !(a == b);
+}
+
class CounterContentData final : public ContentData {
public:
explicit CounterContentData(std::unique_ptr<CounterContent> counter)
- : m_counter(std::move(counter))
+ : ContentData(CounterDataType)
+ , m_counter(WTFMove(counter))
{
+ ASSERT(m_counter);
}
- const CounterContent* counter() const { return m_counter.get(); }
- void setCounter(std::unique_ptr<CounterContent> counter) { m_counter = std::move(counter); }
-
- virtual bool isCounter() const override { return true; }
- virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
-
-private:
- virtual std::unique_ptr<ContentData> cloneInternal() const override
+ const CounterContent& counter() const { return *m_counter; }
+ void setCounter(std::unique_ptr<CounterContent> counter)
{
- auto counterData = std::make_unique<CounterContent>(*counter());
- return std::make_unique<CounterContentData>(std::move(counterData));
+ ASSERT(counter);
+ m_counter = WTFMove(counter);
}
- virtual bool equals(const ContentData& data) const override
+private:
+ RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const final;
+ std::unique_ptr<ContentData> cloneInternal() const final
{
- if (!data.isCounter())
- return false;
- return *static_cast<const CounterContentData&>(data).counter() == *counter();
+ return std::make_unique<CounterContentData>(std::make_unique<CounterContent>(counter()));
}
std::unique_ptr<CounterContent> m_counter;
};
+inline bool operator==(const CounterContentData& a, const CounterContentData& b)
+{
+ return a.counter() == b.counter();
+}
+
+inline bool operator!=(const CounterContentData& a, const CounterContentData& b)
+{
+ return !(a == b);
+}
+
class QuoteContentData final : public ContentData {
public:
explicit QuoteContentData(QuoteType quote)
- : m_quote(quote)
+ : ContentData(QuoteDataType)
+ , m_quote(quote)
{
}
QuoteType quote() const { return m_quote; }
void setQuote(QuoteType quote) { m_quote = quote; }
- virtual bool isQuote() const override { return true; }
- virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
-
- virtual bool equals(const ContentData& data) const override
- {
- if (!data.isQuote())
- return false;
- return static_cast<const QuoteContentData&>(data).quote() == quote();
- }
-
private:
- virtual std::unique_ptr<ContentData> cloneInternal() const override { return std::make_unique<QuoteContentData>(quote()); }
+ RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const final;
+ std::unique_ptr<ContentData> cloneInternal() const final { return std::make_unique<QuoteContentData>(quote()); }
QuoteType m_quote;
};
+inline bool operator==(const QuoteContentData& a, const QuoteContentData& b)
+{
+ return a.quote() == b.quote();
+}
+
+inline bool operator!=(const QuoteContentData& a, const QuoteContentData& b)
+{
+ return !(a == b);
+}
+
inline bool operator==(const ContentData& a, const ContentData& b)
{
- return a.equals(b);
+ if (a.type() != b.type())
+ return false;
+
+ switch (a.type()) {
+ case ContentData::CounterDataType:
+ return downcast<CounterContentData>(a) == downcast<CounterContentData>(b);
+ case ContentData::ImageDataType:
+ return downcast<ImageContentData>(a) == downcast<ImageContentData>(b);
+ case ContentData::QuoteDataType:
+ return downcast<QuoteContentData>(a) == downcast<QuoteContentData>(b);
+ case ContentData::TextDataType:
+ return downcast<TextContentData>(a) == downcast<TextContentData>(b);
+ }
+
+ ASSERT_NOT_REACHED();
+ return false;
}
inline bool operator!=(const ContentData& a, const ContentData& b)
@@ -191,4 +232,12 @@ inline bool operator!=(const ContentData& a, const ContentData& b)
} // namespace WebCore
-#endif // ContentData_h
+#define SPECIALIZE_TYPE_TRAITS_CONTENT_DATA(ToClassName, ContentDataName) \
+SPECIALIZE_TYPE_TRAITS_BEGIN(WebCore::ToClassName) \
+ static bool isType(const WebCore::ContentData& contentData) { return contentData.is##ContentDataName(); } \
+SPECIALIZE_TYPE_TRAITS_END()
+
+SPECIALIZE_TYPE_TRAITS_CONTENT_DATA(ImageContentData, Image)
+SPECIALIZE_TYPE_TRAITS_CONTENT_DATA(TextContentData, Text)
+SPECIALIZE_TYPE_TRAITS_CONTENT_DATA(CounterContentData, Counter)
+SPECIALIZE_TYPE_TRAITS_CONTENT_DATA(QuoteContentData, Quote)