// vim: set sts=8 ts=2 sw=2 tw=99 et: // // Copyright (C) 2013, David Anderson and AlliedModders LLC // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // // * Redistributions of source code must retain the above copyright notice, this // list of conditions and the following disclaimer. // * 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. // * Neither the name of AlliedModders LLC nor the names of its contributors // may be used to endorse or promote products derived from this software // without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 THE COPYRIGHT HOLDER 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 _include_amtl_inline_list_h_ #define _include_amtl_inline_list_h_ #include namespace ke { template class InlineList; template class InlineListNode { friend class InlineList; public: InlineListNode() : next_(NULL), prev_(NULL) { } InlineListNode(InlineListNode *next, InlineListNode *prev) : next_(next), prev_(prev) { } protected: InlineListNode *next_; InlineListNode *prev_; }; template class InlineList { typedef InlineListNode Node; Node head_; public: InlineList() : head_(&head_, &head_) { } public: class iterator { friend class InlineList; Node *iter_; public: iterator(Node *iter) : iter_(iter) { } iterator & operator ++() { iter_ = iter_->next; return *iter_; } iterator operator ++(int) { iterator old(*this); iter_ = iter_->next_; return old; } T * operator *() { return static_cast(iter_); } T * operator ->() { return static_cast(iter_); } bool operator !=(const iterator &where) const { return iter_ != where.iter_; } bool operator ==(const iterator &where) const { return iter_ == where.iter_; } iterator prev() const { iterator p(iter_->prev_); return p; } iterator next() const { iterator p(iter_->next_); return p; } }; iterator begin() { return iterator(head_.next_); } iterator end() { return iterator(&head_); } void erase(Node *t) { t->prev_->next_ = t->next_; t->next_->prev_ = t->prev_; } void insert(Node *t) { t->prev_ = head_.prev_; t->next_ = &head_; head_.prev_->next_ = t; head_.prev_ = t; } }; } #endif // _include_amtl_inline_list_h_