1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2025-02-07 21:37:14 +01:00
SqMod/vendor/POCO/Util/src/LayeredConfiguration.cpp
Sandu Liviu Catalin 4a6bfc086c Major plugin refactor and cleanup.
Switched to POCO library for unified platform/library interface.
Deprecated the external module API. It was creating more problems than solving.
Removed most built-in libraries in favor of system libraries for easier maintenance.
Cleaned and secured code with help from static analyzers.
2021-01-30 08:51:39 +02:00

186 lines
3.4 KiB
C++

//
// LayeredConfiguration.cpp
//
// Library: Util
// Package: Configuration
// Module: LayeredConfiguration
//
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// SPDX-License-Identifier: BSL-1.0
//
#include "Poco/Util/LayeredConfiguration.h"
#include "Poco/Exception.h"
#include <set>
using Poco::AutoPtr;
using Poco::RuntimeException;
namespace Poco {
namespace Util {
LayeredConfiguration::LayeredConfiguration()
{
}
LayeredConfiguration::~LayeredConfiguration()
{
}
void LayeredConfiguration::add(AbstractConfiguration::Ptr pConfig)
{
add(pConfig, highest(), false);
}
void LayeredConfiguration::add(AbstractConfiguration::Ptr pConfig, const std::string& label)
{
add(pConfig, label, highest(), false);
}
void LayeredConfiguration::add(AbstractConfiguration::Ptr pConfig, int priority)
{
add(pConfig, priority, false);
}
void LayeredConfiguration::add(AbstractConfiguration::Ptr pConfig, const std::string& label, int priority)
{
add(pConfig, label, priority, false);
}
void LayeredConfiguration::addWriteable(AbstractConfiguration::Ptr pConfig, int priority)
{
add(pConfig, priority, true);
}
void LayeredConfiguration::add(AbstractConfiguration::Ptr pConfig, int priority, bool writeable)
{
add(pConfig, std::string(), priority, writeable);
}
void LayeredConfiguration::add(AbstractConfiguration::Ptr pConfig, const std::string& label, int priority, bool writeable)
{
ConfigItem item;
item.pConfig = pConfig;
item.priority = priority;
item.writeable = writeable;
item.label = label;
ConfigList::iterator it = _configs.begin();
while (it != _configs.end() && it->priority < priority) ++it;
_configs.insert(it, item);
}
void LayeredConfiguration::removeConfiguration(AbstractConfiguration::Ptr pConfig)
{
for (ConfigList::iterator it = _configs.begin(); it != _configs.end(); ++it)
{
if (it->pConfig == pConfig)
{
_configs.erase(it);
break;
}
}
}
AbstractConfiguration::Ptr LayeredConfiguration::find(const std::string& label) const
{
for (const auto& conf: _configs)
{
if (conf.label == label) return conf.pConfig;
}
return 0;
}
bool LayeredConfiguration::getRaw(const std::string& key, std::string& value) const
{
for (const auto& conf: _configs)
{
if (conf.pConfig->getRaw(key, value)) return true;
}
return false;
}
void LayeredConfiguration::setRaw(const std::string& key, const std::string& value)
{
for (auto& conf: _configs)
{
if (conf.writeable)
{
conf.pConfig->setRaw(key, value);
return;
}
}
throw RuntimeException("No writeable configuration object to store the property", key);
}
void LayeredConfiguration::enumerate(const std::string& key, Keys& range) const
{
std::set<std::string> keys;
for (const auto& conf: _configs)
{
Keys partRange;
conf.pConfig->enumerate(key, partRange);
for (const auto& k: partRange)
{
if (keys.find(k) == keys.end())
{
range.push_back(k);
keys.insert(k);
}
}
}
}
void LayeredConfiguration::removeRaw(const std::string& key)
{
for (auto& conf: _configs)
{
if (conf.writeable)
{
conf.pConfig->remove(key);
return;
}
}
}
int LayeredConfiguration::lowest() const
{
if (_configs.empty())
return 0;
else
return _configs.front().priority - 1;
}
int LayeredConfiguration::highest() const
{
if (_configs.empty())
return 0;
else
return _configs.back().priority + 1;
}
} } // namespace Poco::Util