bugfix in submode check logic
This commit is contained in:
parent
4c48668125
commit
af58c414fc
@ -25,13 +25,18 @@ ReturnValue_t SubsystemBase::checkStateAgainstTable(HybridIterator<ModeListEntry
|
||||
std::map<object_id_t, ChildInfo>::iterator childIter;
|
||||
|
||||
auto checkSubmode = [&]() {
|
||||
uint8_t mask;
|
||||
bool submodesAllowedMask = tableIter.value->submodesAllowed(&mask);
|
||||
uint8_t submodeToCheckAgainst = tableIter.value->getSubmode();
|
||||
if (tableIter.value->inheritSubmode()) {
|
||||
if (childIter->second.submode != targetSubmode) {
|
||||
submodeToCheckAgainst = targetSubmode;
|
||||
}
|
||||
if (not submodesAllowedMask) {
|
||||
if (childIter->second.submode != submodeToCheckAgainst) {
|
||||
return returnvalue::FAILED;
|
||||
}
|
||||
}
|
||||
uint8_t mask;
|
||||
if (tableIter.value->submodesAllowed(&mask)) {
|
||||
if (submodesAllowedMask) {
|
||||
if ((childIter->second.submode | mask) != mask) {
|
||||
return returnvalue::FAILED;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user