diff options
Diffstat (limited to 'include/core')
-rw-r--r-- | include/core/SkTInternalLList.h | 272 |
1 files changed, 0 insertions, 272 deletions
diff --git a/include/core/SkTInternalLList.h b/include/core/SkTInternalLList.h deleted file mode 100644 index 1aa1a12209..0000000000 --- a/include/core/SkTInternalLList.h +++ /dev/null @@ -1,272 +0,0 @@ -/* - * Copyright 2012 Google Inc. - * - * Use of this source code is governed by a BSD-style license that can be - * found in the LICENSE file. - */ - -#ifndef SkTInternalLList_DEFINED -#define SkTInternalLList_DEFINED - -#include "SkTypes.h" - -/** - * Helper class to automatically initialize the doubly linked list created pointers. - */ -template <typename T> class SkPtrWrapper { - public: - SkPtrWrapper() : fPtr(NULL) {} - SkPtrWrapper& operator =(T* ptr) { fPtr = ptr; return *this; } - operator T*() const { return fPtr; } - T* operator->() { return fPtr; } - private: - T* fPtr; -}; - - -/** - * This macro creates the member variables required by the SkTInternalLList class. It should be - * placed in the private section of any class that will be stored in a double linked list. - */ -#define SK_DECLARE_INTERNAL_LLIST_INTERFACE(ClassName) \ - friend class SkTInternalLList<ClassName>; \ - /* back pointer to the owning list - for debugging */ \ - SkDEBUGCODE(SkPtrWrapper<SkTInternalLList<ClassName> > fList;) \ - SkPtrWrapper<ClassName> fPrev; \ - SkPtrWrapper<ClassName> fNext - -/** - * This class implements a templated internal doubly linked list data structure. - */ -template <class T> class SkTInternalLList : SkNoncopyable { -public: - SkTInternalLList() - : fHead(NULL) - , fTail(NULL) { - } - - void remove(T* entry) { - SkASSERT(fHead && fTail); - SkASSERT(this->isInList(entry)); - - T* prev = entry->fPrev; - T* next = entry->fNext; - - if (prev) { - prev->fNext = next; - } else { - fHead = next; - } - if (next) { - next->fPrev = prev; - } else { - fTail = prev; - } - - entry->fPrev = NULL; - entry->fNext = NULL; - -#ifdef SK_DEBUG - entry->fList = NULL; -#endif - } - - void addToHead(T* entry) { - SkASSERT(NULL == entry->fPrev && NULL == entry->fNext); - SkASSERT(NULL == entry->fList); - - entry->fPrev = NULL; - entry->fNext = fHead; - if (fHead) { - fHead->fPrev = entry; - } - fHead = entry; - if (NULL == fTail) { - fTail = entry; - } - -#ifdef SK_DEBUG - entry->fList = this; -#endif - } - - void addToTail(T* entry) { - SkASSERT(NULL == entry->fPrev && NULL == entry->fNext); - SkASSERT(NULL == entry->fList); - - entry->fPrev = fTail; - entry->fNext = NULL; - if (fTail) { - fTail->fNext = entry; - } - fTail = entry; - if (NULL == fHead) { - fHead = entry; - } - -#ifdef SK_DEBUG - entry->fList = this; -#endif - } - - /** - * Inserts a new list entry before an existing list entry. The new entry must not already be - * a member of this or any other list. If existingEntry is NULL then the new entry is added - * at the tail. - */ - void addBefore(T* newEntry, T* existingEntry) { - SkASSERT(newEntry); - - if (NULL == existingEntry) { - this->addToTail(newEntry); - return; - } - - SkASSERT(this->isInList(existingEntry)); - newEntry->fNext = existingEntry; - T* prev = existingEntry->fPrev; - existingEntry->fPrev = newEntry; - newEntry->fPrev = prev; - if (NULL == prev) { - SkASSERT(fHead == existingEntry); - fHead = newEntry; - } else { - prev->fNext = newEntry; - } -#ifdef SK_DEBUG - newEntry->fList = this; -#endif - } - - /** - * Inserts a new list entry after an existing list entry. The new entry must not already be - * a member of this or any other list. If existingEntry is NULL then the new entry is added - * at the head. - */ - void addAfter(T* newEntry, T* existingEntry) { - SkASSERT(newEntry); - - if (NULL == existingEntry) { - this->addToHead(newEntry); - return; - } - - SkASSERT(this->isInList(existingEntry)); - newEntry->fPrev = existingEntry; - T* next = existingEntry->fNext; - existingEntry->fNext = newEntry; - newEntry->fNext = next; - if (NULL == next) { - SkASSERT(fTail == existingEntry); - fTail = newEntry; - } else { - next->fPrev = newEntry; - } -#ifdef SK_DEBUG - newEntry->fList = this; -#endif - } - - bool isEmpty() const { - return NULL == fHead && NULL == fTail; - } - - T* head() { return fHead; } - T* tail() { return fTail; } - - class Iter { - public: - enum IterStart { - kHead_IterStart, - kTail_IterStart - }; - - Iter() : fCurr(NULL) {} - Iter(const Iter& iter) : fCurr(iter.fCurr) {} - Iter& operator= (const Iter& iter) { fCurr = iter.fCurr; return *this; } - - T* init(const SkTInternalLList& list, IterStart startLoc) { - if (kHead_IterStart == startLoc) { - fCurr = list.fHead; - } else { - SkASSERT(kTail_IterStart == startLoc); - fCurr = list.fTail; - } - - return fCurr; - } - - T* get() { return fCurr; } - - /** - * Return the next/previous element in the list or NULL if at the end. - */ - T* next() { - if (NULL == fCurr) { - return NULL; - } - - fCurr = fCurr->fNext; - return fCurr; - } - - T* prev() { - if (NULL == fCurr) { - return NULL; - } - - fCurr = fCurr->fPrev; - return fCurr; - } - - private: - T* fCurr; - }; - -#ifdef SK_DEBUG - void validate() const { - SkASSERT(!fHead == !fTail); - Iter iter; - for (T* item = iter.init(*this, Iter::kHead_IterStart); item; item = iter.next()) { - SkASSERT(this->isInList(item)); - if (NULL == item->fPrev) { - SkASSERT(fHead == item); - } else { - SkASSERT(item->fPrev->fNext == item); - } - if (NULL == item->fNext) { - SkASSERT(fTail == item); - } else { - SkASSERT(item->fNext->fPrev == item); - } - } - } - - /** - * Debugging-only method that uses the list back pointer to check if 'entry' is indeed in 'this' - * list. - */ - bool isInList(const T* entry) const { - return entry->fList == this; - } - - /** - * Debugging-only method that laboriously counts the list entries. - */ - int countEntries() const { - int count = 0; - for (T* entry = fHead; entry; entry = entry->fNext) { - ++count; - } - return count; - } -#endif // SK_DEBUG - -private: - T* fHead; - T* fTail; - - typedef SkNoncopyable INHERITED; -}; - -#endif |