/* Copyright (C) 2004, 2005, 2006, 2008 Nikolas Zimmermann 2004, 2005 Rob Buis This file is part of the KDE 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef SVGList_h #define SVGList_h #if ENABLE(SVG) #include "ExceptionCode.h" #include "SVGListTraits.h" #include #include #include namespace WebCore { class QualifiedName; template struct SVGListTypeOperations { static Item nullItem() { return SVGListTraits::value, Item>::nullItem(); } }; template class SVGList : public RefCounted > { private: typedef SVGListTypeOperations TypeOperations; public: virtual ~SVGList() { } const QualifiedName& associatedAttributeName() const { return m_associatedAttributeName; } unsigned int numberOfItems() const { return m_vector.size(); } void clear(ExceptionCode &) { m_vector.clear(); } Item initialize(Item newItem, ExceptionCode& ec) { clear(ec); return appendItem(newItem, ec); } Item getFirst() const { ExceptionCode ec = 0; return getItem(0, ec); } Item getLast() const { ExceptionCode ec = 0; return getItem(m_vector.size() - 1, ec); } Item getItem(unsigned int index, ExceptionCode& ec) { if (index >= m_vector.size()) { ec = INDEX_SIZE_ERR; return TypeOperations::nullItem(); } return m_vector.at(index); } const Item getItem(unsigned int index, ExceptionCode& ec) const { if (index >= m_vector.size()) { ec = INDEX_SIZE_ERR; return TypeOperations::nullItem(); } return m_vector[index]; } Item insertItemBefore(Item newItem, unsigned int index, ExceptionCode&) { if (index < m_vector.size()) { m_vector.insert(index, newItem); } else { m_vector.append(newItem); } return newItem; } Item replaceItem(Item newItem, unsigned int index, ExceptionCode& ec) { if (index >= m_vector.size()) { ec = INDEX_SIZE_ERR; return TypeOperations::nullItem(); } m_vector[index] = newItem; return newItem; } Item removeItem(unsigned int index, ExceptionCode& ec) { if (index >= m_vector.size()) { ec = INDEX_SIZE_ERR; return TypeOperations::nullItem(); } Item item = m_vector[index]; m_vector.remove(index); return item; } Item appendItem(Item newItem, ExceptionCode&) { m_vector.append(newItem); return newItem; } protected: SVGList(const QualifiedName& attributeName) : m_associatedAttributeName(attributeName) { } private: Vector m_vector; const QualifiedName& m_associatedAttributeName; }; template class SVGPODListItem : public RefCounted > { public: static PassRefPtr create() { return adoptRef(new SVGPODListItem); } static PassRefPtr copy(const Item& item) { return adoptRef(new SVGPODListItem(item)); } operator Item&() { return m_item; } operator const Item&() const { return m_item; } // Updating facilities, used by JSSVGPODTypeWrapperCreatorForList Item value() const { return m_item; } void setValue(Item newItem) { m_item = newItem; } private: SVGPODListItem() : m_item() { } SVGPODListItem(const Item& item) : RefCounted >(), m_item(item) { } Item m_item; }; template class SVGPODList : public SVGList > > { public: Item initialize(Item newItem, ExceptionCode& ec) { SVGPODListItem* ptr(SVGList > >::initialize(SVGPODListItem::copy(newItem), ec).get()); if (!ptr) return Item(); return static_cast(*ptr); } Item getFirst() const { SVGPODListItem* ptr(SVGList > >::getFirst().get()); if (!ptr) return Item(); return static_cast(*ptr); } Item getLast() const { SVGPODListItem* ptr(SVGList > >::getLast().get()); if (!ptr) return Item(); return static_cast(*ptr); } Item getItem(unsigned int index, ExceptionCode& ec) { SVGPODListItem* ptr(SVGList > >::getItem(index, ec).get()); if (!ptr) return Item(); return static_cast(*ptr); } const Item getItem(unsigned int index, ExceptionCode& ec) const { SVGPODListItem* ptr(SVGList > >::getItem(index, ec).get()); if (!ptr) return Item(); return static_cast(*ptr); } Item insertItemBefore(Item newItem, unsigned int index, ExceptionCode& ec) { SVGPODListItem* ptr(SVGList > >::insertItemBefore(SVGPODListItem::copy(newItem), index, ec).get()); if (!ptr) return Item(); return static_cast(*ptr); } Item replaceItem(Item newItem, unsigned int index, ExceptionCode& ec) { SVGPODListItem* ptr(SVGList > >::replaceItem(SVGPODListItem::copy(newItem), index, ec).get()); if (!ptr) return Item(); return static_cast(*ptr); } Item removeItem(unsigned int index, ExceptionCode& ec) { SVGPODListItem* ptr(SVGList > >::removeItem(index, ec).get()); if (!ptr) return Item(); return static_cast(*ptr); } Item appendItem(Item newItem, ExceptionCode& ec) { SVGPODListItem* ptr(SVGList > >::appendItem(SVGPODListItem::copy(newItem), ec).get()); if (!ptr) return Item(); return static_cast(*ptr); } protected: SVGPODList(const QualifiedName& attributeName) : SVGList > >(attributeName) { } }; } // namespace WebCore #endif // ENABLE(SVG) #endif // SVGList_h