mirror of https://github.com/procxx/kepka.git
Use old keys after template autoupdate (support).
This commit is contained in:
parent
a6b325f0d0
commit
052fabcae3
|
@ -331,6 +331,15 @@ void ReplaceFileIndex(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MoveKeys(TemplatesFile &to, const TemplatesFile &from) {
|
||||||
|
const auto &existing = from.questions;
|
||||||
|
for (auto &[normalized, question] : to.questions) {
|
||||||
|
if (const auto i = existing.find(normalized); i != end(existing)) {
|
||||||
|
question.keys = i->second.keys;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Delta ComputeDelta(const TemplatesFile &was, const TemplatesFile &now) {
|
Delta ComputeDelta(const TemplatesFile &was, const TemplatesFile &now) {
|
||||||
auto result = Delta();
|
auto result = Delta();
|
||||||
for (const auto &[normalized, question] : now.questions) {
|
for (const auto &[normalized, question] : now.questions) {
|
||||||
|
@ -522,12 +531,13 @@ void Templates::updateRequestFinished(QNetworkReply *reply) {
|
||||||
errors = std::move(result.errors),
|
errors = std::move(result.errors),
|
||||||
index = std::move(index)
|
index = std::move(index)
|
||||||
]() mutable {
|
]() mutable {
|
||||||
|
auto &existing = _data.files.at(path);
|
||||||
|
auto &parsed = one.files.at(path);
|
||||||
|
details::MoveKeys(parsed, existing);
|
||||||
details::ReplaceFileIndex(_index, details::ComputeIndex(one), path);
|
details::ReplaceFileIndex(_index, details::ComputeIndex(one), path);
|
||||||
if (!errors.isEmpty()) {
|
if (!errors.isEmpty()) {
|
||||||
_errors.fire(std::move(errors));
|
_errors.fire(std::move(errors));
|
||||||
}
|
}
|
||||||
auto &existing = _data.files.at(path);
|
|
||||||
auto &parsed = one.files.at(path);
|
|
||||||
if (const auto delta = details::ComputeDelta(existing, parsed)) {
|
if (const auto delta = details::ComputeDelta(existing, parsed)) {
|
||||||
const auto text = details::FormatUpdateNotification(
|
const auto text = details::FormatUpdateNotification(
|
||||||
path,
|
path,
|
||||||
|
|
Loading…
Reference in New Issue