diff options
Diffstat (limited to 'lib/base/dependencygraph.hpp')
-rw-r--r-- | lib/base/dependencygraph.hpp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/base/dependencygraph.hpp b/lib/base/dependencygraph.hpp new file mode 100644 index 0000000..51aa90e --- /dev/null +++ b/lib/base/dependencygraph.hpp @@ -0,0 +1,34 @@ +/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */ + +#ifndef DEPENDENCYGRAPH_H +#define DEPENDENCYGRAPH_H + +#include "base/i2-base.hpp" +#include "base/object.hpp" +#include <map> +#include <mutex> + +namespace icinga { + +/** + * A graph that tracks dependencies between objects. + * + * @ingroup base + */ +class DependencyGraph +{ +public: + static void AddDependency(Object *parent, Object *child); + static void RemoveDependency(Object *parent, Object *child); + static std::vector<Object::Ptr> GetParents(const Object::Ptr& child); + +private: + DependencyGraph(); + + static std::mutex m_Mutex; + static std::map<Object *, std::map<Object *, int> > m_Dependencies; +}; + +} + +#endif /* DEPENDENCYGRAPH_H */ |