Extended version, which also merges objects of same name and adds array elements as well (if present with same name in both objects):
void mergeJson(QJsonObject& src, const QJsonObject& other)
{
for(auto it = other.constBegin(); it != other.constEnd(); ++it)
{
if(src.contains(it.key()))
{
if(src.value(it.key()).isObject() && other.value(it.key()).isObject())
{
QJsonObject one(src.value(it.key()).toObject());
QJsonObject two(other.value(it.key()).toObject());
mergeJson(one, two);
src[it.key()] = one;
}
else if(src.value(it.key()).isArray() && other.value(it.key()).isArray())
{
QJsonArray arr = other.value(it.key()).toArray();
QJsonArray srcArr = src.value(it.key()).toArray();
for(int i = 0; i < arr.size(); i++)
srcArr.append(arr[i]);
src[it.key()] = srcArr;
}
}
else
src[it.key()] = it.value();
}
}
If src
and other
have a field with the same name (except arrays and objects, see top), src will be used.
src:
{
"arr":[
{
"fieldOne":"dqwd",
"fieldTwo":"dqwd2"
},
{
"fieldOne":"dqwd",
"fieldTwo":"dqwd2"
},
{
"fieldOne":"dqwd",
"fieldTwo":"dqwd2"
}
],
"fieldOne":"dqwd",
"fieldTwo":"dqwd2",
"two":{
"fieldOne":"dwqwfw",
"fieldTwo":"grew",
"fregtegergwedffe":{
"sdqqwd":"wdqfrg"
}
}
}
other:
{
"arr":[
{
"fieldOne":"dwqwfw",
"fieldTwo":"kjhgf",
"qwdqwd":"grew"
}
],
"fieldOne":"rfgwef",
"grege":"gfewrfew",
"grwefege":"fewfgrew",
"two":{
"fieldOne":"dwqwfw",
"fieldTwo":"kjhgf",
"qwdqwd":"grew"
}
}
merged/src after call:
{
"arr":[
{
"fieldOne":"dqwd",
"fieldTwo":"dqwd2"
},
{
"fieldOne":"dqwd",
"fieldTwo":"dqwd2"
},
{
"fieldOne":"dqwd",
"fieldTwo":"dqwd2"
},
{
"fieldOne":"dwqwfw",
"fieldTwo":"kjhgf",
"qwdqwd":"grew"
}
],
"fieldOne":"dqwd",
"fieldTwo":"dqwd2",
"grege":"gfewrfew",
"grwefege":"fewfgrew",
"two":{
"fieldOne":"dwqwfw",
"fieldTwo":"grew",
"fregtegergwedffe":{
"sdqqwd":"wdqfrg"
},
"qwdqwd":"grew"
}
}