##// END OF EJS Templates
Adds "hybrid" server mode...
Adds "hybrid" server mode Hybrid mode allows to use both the default server and the test server, depending on the "server" setting of each product in the JSON file

File last commit:

r1032:bf587f8540dd
r1118:7dc72cc510ff
Show More
DataSourceItemMergeHelper.cpp
55 lines | 1.7 KiB | text/x-c | CppLexer
/ core / src / DataSource / DataSourceItemMergeHelper.cpp
#include "DataSource/DataSourceItemMergeHelper.h"
#include <DataSource/DataSourceItem.h>
namespace {
/**
* Finds in a tree an item similar to the item passed in parameter
* @param item the item for which to find a similar item
* @param root the root item of the tree
* @return the similar item if found, nullptr otherwise
*/
DataSourceItem *findSimilarItem(const DataSourceItem &item, const DataSourceItem &root)
{
// An item is considered similar to the another item if:
// - the items are both nodes AND
// - the names of the items are identical
if (item.type() != DataSourceItemType::NODE) {
return nullptr;
}
DataSourceItem *result{nullptr};
bool found{false};
for (auto i = 0, count = root.childCount(); i < count && !found; ++i) {
auto child = root.child(i);
found = child->type() == DataSourceItemType::NODE
&& QString::compare(child->name(), item.name(), Qt::CaseInsensitive) == 0;
if (found) {
result = child;
}
}
return result;
}
} // namespace
void DataSourceItemMergeHelper::merge(const DataSourceItem &source, DataSourceItem &dest)
{
// Checks if the source item can be merged into the destination item (i.e. there is a child item
// similar to the source item)
if (auto subItem = findSimilarItem(source, dest)) {
// If there is an item similar to the source item, applies the merge recursively
for (auto i = 0, count = source.childCount(); i < count; ++i) {
merge(*source.child(i), *subItem);
}
}
else {
// If no item is similar to the source item, the item is copied as the child of the
// destination item
dest.appendChild(source.clone());
}
}