mirror of
https://github.com/Icinga/icinga2.git
synced 2025-04-08 17:05:25 +02:00
Apparently there was a reason for making the members of generated classes atomic. However, this was only done for some types, others were still accessed using non-atomic operations. For members of type T::Ptr (i.e. intrusive_ptr<T>), this can result in a double free when multiple threads access the same variable and at least one of them writes to the variable. This commit makes use of std::atomic<T> for more T (it removes the additional constraint sizeof(T) <= sizeof(void*)) and uses a type including a mutex for load and store operations as a fallback.
48 lines
1.0 KiB
Plaintext
48 lines
1.0 KiB
Plaintext
/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
|
|
|
|
#include "icinga/customvarobject.hpp"
|
|
#include "base/function.hpp"
|
|
|
|
library icinga;
|
|
|
|
namespace icinga
|
|
{
|
|
|
|
class TimePeriod : CustomVarObject
|
|
{
|
|
[config] String display_name {
|
|
get {{{
|
|
String displayName = m_DisplayName.load();
|
|
if (displayName.IsEmpty())
|
|
return GetName();
|
|
else
|
|
return displayName;
|
|
}}}
|
|
};
|
|
[config, signal_with_old_value] Dictionary::Ptr ranges;
|
|
[config, required] Function::Ptr update;
|
|
[config] bool prefer_includes {
|
|
default {{{ return true; }}}
|
|
};
|
|
[config, required, signal_with_old_value] array(name(TimePeriod)) excludes {
|
|
default {{{ return new Array(); }}}
|
|
};
|
|
[config, required, signal_with_old_value] array(name(TimePeriod)) includes {
|
|
default {{{ return new Array(); }}}
|
|
};
|
|
[state, no_user_modify] Value valid_begin;
|
|
[state, no_user_modify] Value valid_end;
|
|
[state, no_user_modify] Array::Ptr segments;
|
|
[no_storage] bool is_inside {
|
|
get;
|
|
};
|
|
};
|
|
|
|
validator TimePeriod {
|
|
Dictionary ranges {
|
|
String "*";
|
|
};
|
|
};
|
|
|
|
}
|