util/IntrusiveList: add IntrusiveList::swap()

This commit is contained in:
Max Kellermann 2021-10-02 16:23:08 +02:00 committed by Max Kellermann
parent 2b30ac2351
commit 8d679e7e00

View File

@ -167,6 +167,29 @@ public:
IntrusiveList &operator=(IntrusiveList &&) = delete; IntrusiveList &operator=(IntrusiveList &&) = delete;
friend void swap(IntrusiveList &a, IntrusiveList &b) noexcept {
using std::swap;
if (a.empty()) {
if (b.empty())
return;
a.head = b.head;
a.head.next->prev = &a.head;
a.head.prev->next = &a.head;
b.head = {&b.head, &b.head};
} else {
swap(a.head, b.head);
a.head.next->prev = &a.head;
a.head.prev->next = &a.head;
b.head.next->prev = &b.head;
b.head.prev->next = &b.head;
}
}
constexpr bool empty() const noexcept { constexpr bool empty() const noexcept {
return head.next == &head; return head.next == &head;
} }