blob: 894b57dd5123bb55c5d9ef67431281ac61f1ee78 [file] [log] [blame]
/*
* Copyright (C) Research In Motion Limited 2010. 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.
*/
#pragma once
#include "RenderSVGHiddenContainer.h"
#include "RenderSVGResource.h"
#include "SVGDocumentExtensions.h"
namespace WebCore {
class RenderLayer;
class RenderSVGResourceContainer : public RenderSVGHiddenContainer,
public RenderSVGResource {
WTF_MAKE_ISO_ALLOCATED(RenderSVGResourceContainer);
public:
virtual ~RenderSVGResourceContainer();
void layout() override;
void styleDidChange(StyleDifference, const RenderStyle* oldStyle) final;
bool isSVGResourceContainer() const final { return true; }
static bool shouldTransformOnTextPainting(const RenderElement&, AffineTransform&);
static AffineTransform transformOnNonScalingStroke(RenderObject*, const AffineTransform& resourceTransform);
void idChanged();
void addClientRenderLayer(RenderLayer*);
void removeClientRenderLayer(RenderLayer*);
protected:
RenderSVGResourceContainer(SVGElement&, RenderStyle&&);
enum InvalidationMode {
LayoutAndBoundariesInvalidation,
BoundariesInvalidation,
RepaintInvalidation,
ParentOnlyInvalidation
};
// Used from the invalidateClient/invalidateClients methods from classes, inheriting from us.
virtual bool selfNeedsClientInvalidation() const { return everHadLayout() && selfNeedsLayout(); }
void markAllClientsForInvalidation(InvalidationMode);
void markAllClientLayersForInvalidation();
void markClientForInvalidation(RenderObject&, InvalidationMode);
private:
friend class SVGResourcesCache;
void addClient(RenderElement&);
void removeClient(RenderElement&);
void willBeDestroyed() final;
void registerResource();
AtomString m_id;
HashSet<RenderElement*> m_clients;
HashSet<RenderLayer*> m_clientLayers;
bool m_registered { false };
bool m_isInvalidating { false };
};
inline RenderSVGResourceContainer* getRenderSVGResourceContainerById(Document& document, const AtomString& id)
{
if (id.isEmpty())
return nullptr;
if (RenderSVGResourceContainer* renderResource = document.accessSVGExtensions().resourceById(id))
return renderResource;
return nullptr;
}
template<typename Renderer>
Renderer* getRenderSVGResourceById(Document& document, const AtomString& id)
{
// Using the RenderSVGResource type here avoids ambiguous casts for types that
// descend from both RenderObject and RenderSVGResourceContainer.
RenderSVGResource* container = getRenderSVGResourceContainerById(document, id);
if (is<Renderer>(container))
return downcast<Renderer>(container);
return nullptr;
}
} // namespace WebCore
SPECIALIZE_TYPE_TRAITS_RENDER_OBJECT(RenderSVGResourceContainer, isSVGResourceContainer())