/* * This file is part of the AzerothCore Project. See AUTHORS file for Copyright information * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU Affero General Public License as published by the * Free Software Foundation; either version 3 of the License, or (at your * option) any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for * more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ #ifndef _REFMANAGER_H #define _REFMANAGER_H //===================================================== #include "Dynamic/LinkedList.h" #include "Dynamic/LinkedReference/Reference.h" template class RefMgr : public LinkedListHead { public: typedef LinkedListHead::Iterator< Reference> iterator; RefMgr() = default; virtual ~RefMgr() { clearReferences(); } Reference* getFirst() { return ((Reference*) LinkedListHead::getFirst()); } [[nodiscard]] Reference const* getFirst() const { return ((Reference const*) LinkedListHead::getFirst()); } Reference* getLast() { return ((Reference*) LinkedListHead::getLast()); } [[nodiscard]] Reference const* getLast() const { return ((Reference const*) LinkedListHead::getLast()); } iterator begin() { return iterator(getFirst()); } iterator end() { return iterator(nullptr); } iterator rbegin() { return iterator(getLast()); } iterator rend() { return iterator(nullptr); } void clearReferences() { LinkedListElement* ref; while ((ref = getFirst()) != nullptr) { ((Reference*) ref)->invalidate(); ref->delink(); // the delink might be already done by invalidate(), but doing it here again does not hurt and insures an empty list } } }; //===================================================== #endif