1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file LICENSE.rst or https://cmake.org/licensing for details. */
#include "cmCTestResourceAllocator.h"
#include <utility>
#include <vector>
#include "cmCTestResourceSpec.h"
void cmCTestResourceAllocator::InitializeFromResourceSpec(
cmCTestResourceSpec const& spec)
{
this->Resources.clear();
for (auto const& it : spec.LocalSocket.Resources) {
auto& res = this->Resources[it.first];
for (auto const& specRes : it.second) {
res[specRes.Id].Total = specRes.Capacity;
res[specRes.Id].Locked = 0;
}
}
}
std::map<std::string,
std::map<std::string, cmCTestResourceAllocator::Resource>> const&
cmCTestResourceAllocator::GetResources() const
{
return this->Resources;
}
bool cmCTestResourceAllocator::AllocateResource(std::string const& name,
std::string const& id,
unsigned int slots)
{
auto it = this->Resources.find(name);
if (it == this->Resources.end()) {
return false;
}
auto resIt = it->second.find(id);
if (resIt == it->second.end()) {
return false;
}
if (resIt->second.Total < resIt->second.Locked + slots) {
return false;
}
resIt->second.Locked += slots;
return true;
}
bool cmCTestResourceAllocator::DeallocateResource(std::string const& name,
std::string const& id,
unsigned int slots)
{
auto it = this->Resources.find(name);
if (it == this->Resources.end()) {
return false;
}
auto resIt = it->second.find(id);
if (resIt == it->second.end()) {
return false;
}
if (resIt->second.Locked < slots) {
return false;
}
resIt->second.Locked -= slots;
return true;
}
bool cmCTestResourceAllocator::Resource::operator==(
Resource const& other) const
{
return this->Total == other.Total && this->Locked == other.Locked;
}
bool cmCTestResourceAllocator::Resource::operator!=(
Resource const& other) const
{
return !(*this == other);
}
|