mirror of
https://github.com/zeldaret/ss
synced 2026-06-25 01:32:01 -04:00
Matching. Pulled from ogws
This commit is contained in:
@@ -0,0 +1,76 @@
|
||||
#include <nw4r/ut/ut_LinkList.h>
|
||||
|
||||
namespace nw4r {
|
||||
namespace ut {
|
||||
namespace detail {
|
||||
|
||||
/* 8042a850 */
|
||||
LinkListImpl::~LinkListImpl() {
|
||||
Clear();
|
||||
}
|
||||
|
||||
/* 8042a8e0 */
|
||||
LinkListImpl::Iterator LinkListImpl::Erase(LinkListImpl::Iterator it) {
|
||||
Iterator copy(it);
|
||||
return Erase(it, ++copy);
|
||||
}
|
||||
|
||||
/* 8042a930 */
|
||||
void LinkListImpl::Clear() {
|
||||
Erase(GetBeginIter(), GetEndIter());
|
||||
}
|
||||
|
||||
/* 8042a980 */
|
||||
LinkListImpl::Iterator LinkListImpl::Insert(Iterator it, LinkListNode *p) {
|
||||
LinkListNode *next = it.mNode;
|
||||
LinkListNode *prev = next->mPrev;
|
||||
|
||||
// prev <- p -> next
|
||||
p->mNext = next;
|
||||
p->mPrev = prev;
|
||||
// prev <-> p <-> next
|
||||
next->mPrev = p;
|
||||
prev->mNext = p;
|
||||
|
||||
mSize++;
|
||||
|
||||
return Iterator(p);
|
||||
}
|
||||
|
||||
/* 8042a9b0 */
|
||||
LinkListImpl::Iterator LinkListImpl::Erase(LinkListNode *p) {
|
||||
LinkListNode *next = p->mNext;
|
||||
LinkListNode *prev = p->mPrev;
|
||||
|
||||
// Remove connections to node
|
||||
next->mPrev = prev;
|
||||
prev->mNext = next;
|
||||
|
||||
mSize--;
|
||||
|
||||
// Isolate node
|
||||
p->mNext = NULL;
|
||||
p->mPrev = NULL;
|
||||
|
||||
return Iterator(next);
|
||||
}
|
||||
|
||||
/* Not in SS */
|
||||
LinkListImpl::Iterator LinkListImpl::Erase(Iterator begin, Iterator end) {
|
||||
LinkListNode *pCur = begin.mNode;
|
||||
LinkListNode *pEnd = end.mNode;
|
||||
|
||||
while (pCur != pEnd) {
|
||||
// Preserve next node before erasing pointers
|
||||
LinkListNode *pNext = pCur->mNext;
|
||||
// Erase current node
|
||||
Erase(pCur);
|
||||
pCur = pNext;
|
||||
}
|
||||
|
||||
return Iterator(pEnd);
|
||||
}
|
||||
|
||||
} // namespace detail
|
||||
} // namespace ut
|
||||
} // namespace nw4r
|
||||
Reference in New Issue
Block a user