1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
|
/*
* Copyright (C) 1999 Antti Koivisto (koivisto@kde.org)
* Copyright (C) 2004-2017 Apple Inc. All rights reserved.
*
* 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.
*
*/
#include "config.h"
#include "StyleBackgroundData.h"
#include "BorderData.h"
#include "RenderStyleConstants.h"
#include "RenderStyleDifference.h"
#include "RenderStyleInlines.h"
namespace WebCore {
DEFINE_ALLOCATOR_WITH_HEAP_IDENTIFIER(StyleBackgroundData);
StyleBackgroundData::StyleBackgroundData()
: background(FillLayer::create(FillLayerType::Background))
, color(RenderStyle::initialBackgroundColor())
{
}
inline StyleBackgroundData::StyleBackgroundData(const StyleBackgroundData& other)
: RefCounted<StyleBackgroundData>()
, background(other.background)
, color(other.color)
, outline(other.outline)
{
}
Ref<StyleBackgroundData> StyleBackgroundData::copy() const
{
return adoptRef(*new StyleBackgroundData(*this));
}
bool StyleBackgroundData::operator==(const StyleBackgroundData& other) const
{
return background == other.background && color == other.color && outline == other.outline;
}
bool StyleBackgroundData::isEquivalentForPainting(const StyleBackgroundData& other, bool currentColorDiffers) const
{
if (background != other.background || color != other.color)
return false;
if (currentColorDiffers && color.containsCurrentColor())
return false;
if (!outline.isVisible() && !other.outline.isVisible())
return true;
if (currentColorDiffers && outline.color().containsCurrentColor())
return false;
return outline == other.outline;
}
void StyleBackgroundData::dump(TextStream& ts, DumpStyleValues behavior) const
{
if (behavior == DumpStyleValues::All || *background != FillLayer::create(FillLayerType::Background).get())
ts.dumpProperty("background-image", background);
if (behavior == DumpStyleValues::All || color != RenderStyle::initialBackgroundColor())
ts.dumpProperty("background-color", color);
if (behavior == DumpStyleValues::All || outline != OutlineValue())
ts.dumpProperty("outline", outline);
}
#if !LOG_DISABLED
void StyleBackgroundData::dumpDifferences(TextStream& ts, const StyleBackgroundData& other) const
{
LOG_IF_DIFFERENT(background);
LOG_IF_DIFFERENT(color);
LOG_IF_DIFFERENT(outline);
}
#endif
TextStream& operator<<(TextStream& ts, const StyleBackgroundData& backgroundData)
{
backgroundData.dump(ts);
return ts;
}
} // namespace WebCore
|