icinga2/lib/base/configtype.hpp

139 lines
4.1 KiB
C++
Raw Normal View History

/******************************************************************************
* Icinga 2 *
2016-01-12 08:29:59 +01:00
* Copyright (C) 2012-2016 Icinga Development Team (https://www.icinga.org/) *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* 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 General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software Foundation *
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
#ifndef DYNAMICTYPE_H
#define DYNAMICTYPE_H
2014-05-25 16:23:35 +02:00
#include "base/i2-base.hpp"
#include "base/configobject.hpp"
2014-05-25 16:23:35 +02:00
#include "base/objectlock.hpp"
2013-03-16 21:18:53 +01:00
#include <map>
# include <boost/iterator/iterator_facade.hpp>
2013-03-15 18:21:29 +01:00
namespace icinga
{
template<typename T>
class ConfigTypeIterator;
class I2_BASE_API ConfigType : public Object
{
public:
DECLARE_PTR_TYPEDEFS(ConfigType);
ConfigType(const String& name);
String GetName(void) const;
static ConfigType::Ptr GetByName(const String& name);
ConfigObject::Ptr GetObject(const String& name) const;
void RegisterObject(const ConfigObject::Ptr& object);
void UnregisterObject(const ConfigObject::Ptr& object);
static std::vector<ConfigType::Ptr> GetTypes(void);
std::pair<ConfigTypeIterator<ConfigObject>, ConfigTypeIterator<ConfigObject> > GetObjects(void);
2013-02-18 23:44:24 +01:00
template<typename T>
static std::pair<ConfigTypeIterator<T>, ConfigTypeIterator<T> > GetObjectsByType(void)
{
ConfigType::Ptr type = GetByName(T::GetTypeName());
return std::make_pair(
ConfigTypeIterator<T>(type, 0),
ConfigTypeIterator<T>(type, UINT_MAX)
);
}
private:
template<typename T> friend class ConfigTypeIterator;
String m_Name;
typedef std::map<String, ConfigObject::Ptr> ObjectMap;
typedef std::vector<ConfigObject::Ptr> ObjectVector;
2013-02-18 23:44:24 +01:00
ObjectMap m_ObjectMap;
ObjectVector m_ObjectVector;
2013-02-18 23:44:24 +01:00
typedef std::map<String, ConfigType::Ptr> TypeMap;
typedef std::vector<ConfigType::Ptr> TypeVector;
2013-02-18 14:40:24 +01:00
2013-02-18 23:44:24 +01:00
static TypeMap& InternalGetTypeMap(void);
static TypeVector& InternalGetTypeVector(void);
2013-02-18 14:40:24 +01:00
static boost::mutex& GetStaticMutex(void);
};
template<typename T>
class ConfigTypeIterator : public boost::iterator_facade<ConfigTypeIterator<T>, const intrusive_ptr<T>, boost::forward_traversal_tag>
{
public:
ConfigTypeIterator(const ConfigType::Ptr& type, int index)
: m_Type(type), m_Index(index)
{ }
private:
friend class boost::iterator_core_access;
ConfigType::Ptr m_Type;
ConfigType::ObjectVector::size_type m_Index;
mutable intrusive_ptr<T> m_Current;
2014-04-09 12:38:26 +02:00
void increment(void)
{
m_Index++;
}
2014-04-09 12:38:26 +02:00
void decrement(void)
{
m_Index--;
}
void advance(int n)
{
m_Index += n;
}
bool equal(const ConfigTypeIterator<T>& other) const
{
ASSERT(other.m_Type == m_Type);
{
ObjectLock olock(m_Type);
if ((other.m_Index == UINT_MAX || other.m_Index >= other.m_Type->m_ObjectVector.size()) &&
(m_Index == UINT_MAX || m_Index >= m_Type->m_ObjectVector.size()))
return true;
}
return (other.m_Index == m_Index);
}
const intrusive_ptr<T>& dereference(void) const
{
ObjectLock olock(m_Type);
m_Current = static_pointer_cast<T>(*(m_Type->m_ObjectVector.begin() + m_Index));
return m_Current;
}
};
}
#endif /* DYNAMICTYPE_H */