summaryrefslogtreecommitdiff
path: root/src/common/Dynamic/ObjectRegistry.h
blob: 31adcd8f16a703c480bdbb754ff60a0de24b0cc8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
 * 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 <http://www.gnu.org/licenses/>.
 */

#ifndef ACORE_OBJECTREGISTRY_H
#define ACORE_OBJECTREGISTRY_H

#include <map>
#include <memory>
#include <string>

/** ObjectRegistry holds all registry item of the same type
 */
template<class T, class Key = std::string>
class ObjectRegistry final
{
public:
    typedef std::map<Key, std::unique_ptr<T>> RegistryMapType;

    /// Returns a registry item
    T const* GetRegistryItem(Key const& key) const
    {
        auto itr = _registeredObjects.find(key);
        if (itr == _registeredObjects.end())
            return nullptr;
        return itr->second.get();
    }

    static ObjectRegistry<T, Key>* instance()
    {
        static ObjectRegistry<T, Key>* instance = new ObjectRegistry<T, Key>();
        return instance;
    }

    /// Inserts a registry item
    bool InsertItem(T* obj, Key const& key, bool force = false)
    {
        auto itr = _registeredObjects.find(key);
        if (itr != _registeredObjects.end())
        {
            if (!force)
            {
                return false;
            }
            _registeredObjects.erase(itr);
        }

        _registeredObjects.emplace(std::piecewise_construct, std::forward_as_tuple(key), std::forward_as_tuple(obj));
        return true;
    }

    /// Returns true if registry contains an item
    bool HasItem(Key const& key) const
    {
        return (_registeredObjects.count(key) > 0);
    }

    /// Return the map of registered items
    RegistryMapType const& GetRegisteredItems() const
    {
        return _registeredObjects;
    }

private:
    RegistryMapType _registeredObjects;

    // non instanceable, only static
    ObjectRegistry() { }
    ~ObjectRegistry() { }
};

#endif