blob: c065cbea4529154f53748065f194481a3209c0c0 [file] [log] [blame]
/*
* 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) 2006 Graham Dennis (graham.dennis@gmail.com)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#ifndef ContentData_h
#define ContentData_h
#include "CounterContent.h"
#include "StyleImage.h"
#include "RenderPtr.h"
namespace WebCore {
class Document;
class RenderObject;
class RenderStyle;
class ContentData {
WTF_MAKE_FAST_ALLOCATED;
public:
enum Type {
CounterDataType,
ImageDataType,
QuoteDataType,
TextDataType
};
virtual ~ContentData() { }
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 = WTF::move(next); }
void setAltText(const String& alt) { m_altText = alt; }
const String& altText() const { return m_altText; }
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;
};
#define CONTENT_DATA_TYPE_CASTS(ToClassName, FromClassName, ContentDataName) \
TYPE_CASTS_BASE(ToClassName, FromClassName, resource, resource->is##ContentDataName(), resource.is##ContentDataName())
class ImageContentData final : public ContentData {
public:
explicit ImageContentData(PassRefPtr<StyleImage> image)
: ContentData(ImageDataType)
, m_image(image)
{
ASSERT(m_image);
}
const StyleImage& image() const { return *m_image; }
void setImage(PassRefPtr<StyleImage> image)
{
ASSERT(image);
m_image = image;
}
virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
private:
virtual std::unique_ptr<ContentData> cloneInternal() const override
{
return std::make_unique<ImageContentData>(m_image.get());
}
RefPtr<StyleImage> m_image;
};
CONTENT_DATA_TYPE_CASTS(ImageContentData, ContentData, 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)
: ContentData(TextDataType)
, m_text(text)
{
}
const String& text() const { return m_text; }
void setText(const String& text) { m_text = text; }
virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
private:
virtual std::unique_ptr<ContentData> cloneInternal() const override { return std::make_unique<TextContentData>(text()); }
String m_text;
};
CONTENT_DATA_TYPE_CASTS(TextContentData, ContentData, 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)
: ContentData(CounterDataType)
, m_counter(WTF::move(counter))
{
ASSERT(m_counter);
}
const CounterContent& counter() const { return *m_counter; }
void setCounter(std::unique_ptr<CounterContent> counter)
{
ASSERT(counter);
m_counter = WTF::move(counter);
}
virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
private:
virtual std::unique_ptr<ContentData> cloneInternal() const override
{
auto counterData = std::make_unique<CounterContent>(counter());
return std::make_unique<CounterContentData>(WTF::move(counterData));
}
std::unique_ptr<CounterContent> m_counter;
};
CONTENT_DATA_TYPE_CASTS(CounterContentData, ContentData, 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)
: ContentData(QuoteDataType)
, m_quote(quote)
{
}
QuoteType quote() const { return m_quote; }
void setQuote(QuoteType quote) { m_quote = quote; }
virtual RenderPtr<RenderObject> createContentRenderer(Document&, const RenderStyle&) const override;
private:
virtual std::unique_ptr<ContentData> cloneInternal() const override { return std::make_unique<QuoteContentData>(quote()); }
QuoteType m_quote;
};
CONTENT_DATA_TYPE_CASTS(QuoteContentData, ContentData, 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)
{
if (a.type() != b.type())
return false;
switch (a.type()) {
case ContentData::CounterDataType:
return toCounterContentData(a) == toCounterContentData(b);
case ContentData::ImageDataType:
return toImageContentData(a) == toImageContentData(b);
case ContentData::QuoteDataType:
return toQuoteContentData(a) == toQuoteContentData(b);
case ContentData::TextDataType:
return toTextContentData(a) == toTextContentData(b);
}
ASSERT_NOT_REACHED();
return false;
}
inline bool operator!=(const ContentData& a, const ContentData& b)
{
return !(a == b);
}
} // namespace WebCore
#endif // ContentData_h