/* * Copyright (C) 2003 Apple Computer, Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef DeprecatedPtrListImpl_h #define DeprecatedPtrListImpl_h namespace WebCore { class DeprecatedListNode; class DeprecatedPtrListImplIterator; class DeprecatedPtrListImpl { public: DeprecatedPtrListImpl(void (*deleteFunc)(void *)); DeprecatedPtrListImpl(const DeprecatedPtrListImpl &impl); ~DeprecatedPtrListImpl(); bool isEmpty() const { return nodeCount == 0; } unsigned count() const { return nodeCount; } void clear(bool deleteItems); void *at(unsigned n); bool insert(unsigned n, const void *item); bool remove(bool deleteItem); bool remove(unsigned n, bool deleteItem); bool removeFirst(bool deleteItem); bool removeLast(bool deleteItem); bool removeRef(const void *item, bool deleteItem); void *getFirst() const; void *getLast() const; void *getNext() const; void *getPrev() const; void *current() const; void *first(); void *last(); void *next(); void *prev(); void *take(unsigned n); void *take(); void append(const void *item); void prepend(const void *item); unsigned containsRef(const void *item) const; int findRef(const void *item); DeprecatedPtrListImpl &assign(const DeprecatedPtrListImpl &impl, bool deleteItems); private: DeprecatedPtrListImpl &operator =(const DeprecatedPtrListImpl &impl); void swap(DeprecatedPtrListImpl &impl); void addIterator(DeprecatedPtrListImplIterator *iter) const; void removeIterator(DeprecatedPtrListImplIterator *iter) const; DeprecatedListNode *head; DeprecatedListNode *tail; DeprecatedListNode *cur; unsigned nodeCount; void (*deleteItem)(void *); mutable DeprecatedPtrListImplIterator *iterators; friend class DeprecatedPtrListImplIterator; }; class DeprecatedPtrListImplIterator { public: DeprecatedPtrListImplIterator(); DeprecatedPtrListImplIterator(const DeprecatedPtrListImpl &impl); ~DeprecatedPtrListImplIterator(); DeprecatedPtrListImplIterator(const DeprecatedPtrListImplIterator &impl); DeprecatedPtrListImplIterator &operator=(const DeprecatedPtrListImplIterator &impl); unsigned count() const; void *toFirst(); void *toLast(); void *current() const; void *operator--(); void *operator++(); private: const DeprecatedPtrListImpl *list; DeprecatedListNode *node; DeprecatedPtrListImplIterator *next; DeprecatedPtrListImplIterator *prev; friend class DeprecatedPtrListImpl; }; } #endif