2014-03-26 18:19:25 +00:00
|
|
|
#pragma once
|
|
|
|
|
2017-04-16 15:00:33 +00:00
|
|
|
/// Multiple Boolean values. That is, two Boolean values: can it be true, can it be false.
|
2014-03-26 18:19:25 +00:00
|
|
|
struct BoolMask
|
|
|
|
{
|
2019-04-22 16:07:09 +00:00
|
|
|
bool can_be_true = false;
|
|
|
|
bool can_be_false = false;
|
2014-03-26 18:19:25 +00:00
|
|
|
|
2017-04-01 07:20:54 +00:00
|
|
|
BoolMask() {}
|
|
|
|
BoolMask(bool can_be_true_, bool can_be_false_) : can_be_true(can_be_true_), can_be_false(can_be_false_) {}
|
2014-03-26 18:19:25 +00:00
|
|
|
|
2017-04-01 07:20:54 +00:00
|
|
|
BoolMask operator &(const BoolMask & m)
|
|
|
|
{
|
|
|
|
return BoolMask(can_be_true && m.can_be_true, can_be_false || m.can_be_false);
|
|
|
|
}
|
|
|
|
BoolMask operator |(const BoolMask & m)
|
|
|
|
{
|
|
|
|
return BoolMask(can_be_true || m.can_be_true, can_be_false && m.can_be_false);
|
|
|
|
}
|
|
|
|
BoolMask operator !()
|
|
|
|
{
|
|
|
|
return BoolMask(can_be_false, can_be_true);
|
|
|
|
}
|
2020-01-29 21:40:22 +00:00
|
|
|
|
|
|
|
/// If mask is (true, true), then it can no longer change under operation |.
|
|
|
|
/// We use this condition to early-exit KeyConditions::check{InRange,After} methods.
|
|
|
|
bool isComplete() const
|
|
|
|
{
|
|
|
|
return can_be_false && can_be_true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// These special constants are used to implement KeyCondition::mayBeTrue{InRange,After} via KeyCondition::check{InRange,After}.
|
|
|
|
/// When used as an initial_mask argument in KeyCondition::check{InRange,After} methods, they effectively prevent
|
|
|
|
/// calculation of discarded BoolMask component as it is already set to true.
|
|
|
|
static const BoolMask consider_only_can_be_true;
|
|
|
|
static const BoolMask consider_only_can_be_false;
|
2014-03-26 18:19:25 +00:00
|
|
|
};
|