mirror of https://github.com/Icinga/icinga2.git
Fix use of std::unordered_map::insert() as pointed out by Nathaniel Wesley Filardo in GitHup Pull Request #8999
This commit is contained in:
parent
5bba609e60
commit
20d7e1b5e6
|
@ -93,10 +93,13 @@ bool Checkable::IsReachable(DependencyType dt, Dependency::Ptr *failedDependency
|
||||||
|
|
||||||
// tentatively mark this dependency group as failed unless it is already marked;
|
// tentatively mark this dependency group as failed unless it is already marked;
|
||||||
// so it either passed before (don't overwrite) or already failed (so don't care)
|
// so it either passed before (don't overwrite) or already failed (so don't care)
|
||||||
if (violated.find(redundancy_group) == violated.end())
|
// note that std::unordered_map::insert() will not overwrite an existing entry
|
||||||
violated.insert(std::make_pair(redundancy_group, dep));
|
violated.insert(std::make_pair(redundancy_group, dep));
|
||||||
} else if (!redundancy_group.empty()) {
|
} else if (!redundancy_group.empty()) {
|
||||||
// definitely mark this dependency group as passed
|
// definitely mark this dependency group as passed
|
||||||
|
// as std::unordered_map::insert() will not overwrite an existing entry, erase it first
|
||||||
|
// in C++17, one could use std::unorderer_map::insert_or_assign() instead
|
||||||
|
violated.erase(redundancy_group);
|
||||||
violated.insert(std::make_pair(redundancy_group, nullptr));
|
violated.insert(std::make_pair(redundancy_group, nullptr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue