/* Copyright (C) 2006 Apple Computer, Inc. 2006 Nikolas Zimmermann This file is part of the WebKit project 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef SVGDocumentExtensions_h #define SVGDocumentExtensions_h #if ENABLE(SVG) #include #include #include #include "FloatRect.h" #include "StringHash.h" #include "StringImpl.h" #include "AtomicString.h" namespace WebCore { class AtomicString; class Document; class EventListener; class Node; class String; class SVGElement; class SVGElementInstance; class SVGStyledElement; class SVGSVGElement; class TimeScheduler; class SVGDocumentExtensions { public: SVGDocumentExtensions(Document*); ~SVGDocumentExtensions(); PassRefPtr createSVGEventListener(const String& functionName, const String& code, Node*); void addTimeContainer(SVGSVGElement*); void removeTimeContainer(SVGSVGElement*); void startAnimations(); void pauseAnimations(); void unpauseAnimations(); void reportWarning(const String&); void reportError(const String&); private: Document* m_doc; // weak reference HashSet m_timeContainers; // For SVG 1.2 support this will need to be made more general. HashMap*> m_pendingResources; HashMap*> m_elementInstances; SVGDocumentExtensions(const SVGDocumentExtensions&); SVGDocumentExtensions& operator=(const SVGDocumentExtensions&); template HashMap*>* baseValueMap() const { static HashMap*>* s_baseValueMap = new HashMap*>(); return s_baseValueMap; } template static HashMap* genericContextMap() { static HashMap* s_genericContextMap = new HashMap(); return s_genericContextMap; } public: // This HashMap contains a list of pending resources. Pending resources, are such // which are referenced by any object in the SVG document, but do NOT exist yet. // For instance, dynamically build gradients / patterns / clippers... void addPendingResource(const AtomicString& id, SVGStyledElement*); bool isPendingResource(const AtomicString& id) const; std::auto_ptr > removePendingResource(const AtomicString& id); // This HashMap maps elements to their instances, when they are used by elements. // This is needed to synchronize the original element with the internally cloned one. void mapInstanceToElement(SVGElementInstance*, SVGElement*); void removeInstanceMapping(SVGElementInstance*, SVGElement*); HashSet* instancesForElement(SVGElement*) const; // Used by the ANIMATED_PROPERTY_* macros template ValueType baseValue(const SVGElement* element, const AtomicString& propertyName) const { HashMap* propertyMap = baseValueMap()->get(element); if (propertyMap) return propertyMap->get(propertyName.impl()); return 0; } template void setBaseValue(const SVGElement* element, const AtomicString& propertyName, ValueType newValue) { HashMap* propertyMap = baseValueMap()->get(element); if (!propertyMap) { propertyMap = new HashMap(); baseValueMap()->set(element, propertyMap); } propertyMap->set(propertyName.impl(), newValue); } template void removeBaseValue(const SVGElement* element, const AtomicString& propertyName) { HashMap* propertyMap = baseValueMap()->get(element); if (!propertyMap) return; propertyMap->remove(propertyName.impl()); } template bool hasBaseValue(const SVGElement* element, const AtomicString& propertyName) const { HashMap* propertyMap = baseValueMap()->get(element); if (propertyMap) return propertyMap->contains(propertyName.impl()); return false; } // Used by several JS wrappers template const SVGElement* genericContext(const KeyType* obj) const { return genericContextMap()->get(obj); } template void setGenericContext(const KeyType* obj, const SVGElement* context) { genericContextMap()->set(obj, context); } template void removeGenericContext(const KeyType* obj) { genericContextMap()->remove(obj); } template bool hasGenericContext(const KeyType* obj) { return genericContextMap()->contains(obj); } // Used by the generated JS wrappers only template static void forgetGenericContext(const KeyType* obj) { genericContextMap()->remove(obj); } }; // Special handling for WebCore::String template<> inline String SVGDocumentExtensions::baseValue(const SVGElement* element, const AtomicString& propertyName) const { HashMap* propertyMap = baseValueMap()->get(element); if (propertyMap) return propertyMap->get(propertyName.impl()); return String(); } // Special handling for WebCore::FloatRect template<> inline FloatRect SVGDocumentExtensions::baseValue(const SVGElement* element, const AtomicString& propertyName) const { HashMap* propertyMap = baseValueMap()->get(element); if (propertyMap) return propertyMap->get(propertyName.impl()); return FloatRect(); } // Special handling for booleans template<> inline bool SVGDocumentExtensions::baseValue(const SVGElement* element, const AtomicString& propertyName) const { HashMap* propertyMap = baseValueMap()->get(element); if (propertyMap) return propertyMap->get(propertyName.impl()); return false; } // Special handling for doubles template<> inline double SVGDocumentExtensions::baseValue(const SVGElement* element, const AtomicString& propertyName) const { HashMap* propertyMap = baseValueMap()->get(element); if (propertyMap) return propertyMap->get(propertyName.impl()); return 0.0; } } #endif // ENABLE(SVG) #endif