#ifndef SVGElement_h
#define SVGElement_h
#if ENABLE(SVG)
#include "SVGLocatable.h"
#include "SVGParsingError.h"
#include "SVGPropertyInfo.h"
#include "StyledElement.h"
#include "Timer.h"
#include <wtf/HashMap.h>
namespace WebCore {
class AffineTransform;
class CSSCursorImageValue;
class Document;
class SVGAttributeToPropertyMap;
class SVGCursorElement;
class SVGDocumentExtensions;
class SVGElementInstance;
class SVGElementRareData;
class SVGSVGElement;
class SVGElement : public StyledElement {
public:
static PassRefPtr<SVGElement> create(const QualifiedName&, Document*);
virtual ~SVGElement();
bool isOutermostSVGSVGElement() const;
String xmlbase() const;
void setXmlbase(const String&, ExceptionCode&);
SVGSVGElement* ownerSVGElement() const;
SVGElement* viewportElement() const;
SVGDocumentExtensions* accessDocumentSVGExtensions();
virtual bool isStyled() const { return false; }
virtual bool isStyledTransformable() const { return false; }
virtual bool isStyledLocatable() const { return false; }
virtual bool isSVG() const { return false; }
virtual bool isFilterEffect() const { return false; }
virtual bool isGradientStop() const { return false; }
virtual bool isTextContent() const { return false; }
virtual bool isValid() const { return true; }
virtual void svgAttributeChanged(const QualifiedName&) { }
virtual void animatedPropertyTypeForAttribute(const QualifiedName&, Vector<AnimatedPropertyType>&);
void sendSVGLoadEventIfPossible(bool sendParentLoadEvents = false);
void sendSVGLoadEventIfPossibleAsynchronously();
void svgLoadEventTimerFired(Timer<SVGElement>*);
virtual Timer<SVGElement>* svgLoadEventTimer();
virtual AffineTransform* supplementalTransform() { return 0; }
void invalidateSVGAttributes() { clearAreSVGAttributesValid(); }
const HashSet<SVGElementInstance*>& instancesForElement() const;
bool boundingBox(FloatRect&, SVGLocatable::StyleUpdateStrategy = SVGLocatable::AllowStyleUpdate);
void setCursorElement(SVGCursorElement*);
void cursorElementRemoved();
void setCursorImageValue(CSSCursorImageValue*);
void cursorImageValueRemoved();
SVGElement* correspondingElement();
void setCorrespondingElement(SVGElement*);
virtual void updateAnimatedSVGAttribute(const QualifiedName&) const;
virtual PassRefPtr<RenderStyle> customStyleForRenderer();
static void synchronizeRequiredFeatures(void* contextElement);
static void synchronizeRequiredExtensions(void* contextElement);
static void synchronizeSystemLanguage(void* contextElement);
virtual void synchronizeRequiredFeatures() { }
virtual void synchronizeRequiredExtensions() { }
virtual void synchronizeSystemLanguage() { }
virtual SVGAttributeToPropertyMap& localAttributeToPropertyMap();
#ifndef NDEBUG
static bool isAnimatableAttribute(const QualifiedName&);
#endif
StylePropertySet* animatedSMILStyleProperties() const;
StylePropertySet* ensureAnimatedSMILStyleProperties();
void setUseOverrideComputedStyle(bool);
virtual bool haveLoadedRequiredResources();
protected:
SVGElement(const QualifiedName&, Document*, ConstructionType = CreateSVGElement);
virtual void parseAttribute(Attribute*) OVERRIDE;
virtual void finishParsingChildren();
virtual void attributeChanged(Attribute*) OVERRIDE;
virtual bool childShouldCreateRenderer(const NodeRenderingContext&) const;
virtual void removedFrom(Node*) OVERRIDE;
SVGElementRareData* rareSVGData() const;
SVGElementRareData* ensureRareSVGData();
void reportAttributeParsingError(SVGParsingError, Attribute*);
private:
friend class SVGElementInstance;
RenderStyle* computedStyle(PseudoId = NOPSEUDO);
virtual RenderStyle* virtualComputedStyle(PseudoId pseudoElementSpecifier = NOPSEUDO) { return computedStyle(pseudoElementSpecifier); }
virtual bool willRecalcStyle(StyleChange);
virtual bool rendererIsNeeded(const NodeRenderingContext&) { return false; }
virtual bool isSupported(StringImpl* feature, StringImpl* version) const;
void mapInstanceToElement(SVGElementInstance*);
void removeInstanceMapping(SVGElementInstance*);
};
struct SVGAttributeHashTranslator {
static unsigned hash(QualifiedName key)
{
key.setPrefix(nullAtom);
return DefaultHash<QualifiedName>::Hash::hash(key);
}
static bool equal(QualifiedName a, QualifiedName b) { return a.matches(b); }
};
inline SVGElement* toSVGElement(Element* element)
{
ASSERT(!element || element->isSVGElement());
return static_cast<SVGElement*>(element);
}
}
#endif
#endif