aboutsummaryrefslogtreecommitdiff
path: root/contrib/epee
diff options
context:
space:
mode:
authorluigi1111 <luigi1111w@gmail.com>2021-01-06 21:10:30 -0500
committerluigi1111 <luigi1111w@gmail.com>2021-01-06 21:10:30 -0500
commite3acd3e6ba13eb661ecf2249273d41af982634c4 (patch)
tree0b354eba56402db146ad657738652667fe379d91 /contrib/epee
parentMerge pull request #7266 (diff)
parentRestrict duplicate keys in epee binary format (diff)
downloadmonero-e3acd3e6ba13eb661ecf2249273d41af982634c4.tar.xz
Merge pull request #7278
187b4d7 Restrict duplicate keys in epee binary format (Lee Clagett)
Diffstat (limited to 'contrib/epee')
-rw-r--r--contrib/epee/include/storages/portable_storage_from_bin.h5
1 files changed, 4 insertions, 1 deletions
diff --git a/contrib/epee/include/storages/portable_storage_from_bin.h b/contrib/epee/include/storages/portable_storage_from_bin.h
index dfd815f97..5091a3c5f 100644
--- a/contrib/epee/include/storages/portable_storage_from_bin.h
+++ b/contrib/epee/include/storages/portable_storage_from_bin.h
@@ -29,6 +29,7 @@
#pragma once
#include "misc_language.h"
+#include "misc_log_ex.h"
#include "portable_storage_base.h"
#include "portable_storage_bin_utils.h"
@@ -306,7 +307,9 @@ namespace epee
//read section name string
std::string sec_name;
read_sec_name(sec_name);
- sec.m_entries.emplace(std::move(sec_name), load_storage_entry());
+ const auto insert_loc = sec.m_entries.lower_bound(sec_name);
+ CHECK_AND_ASSERT_THROW_MES(insert_loc == sec.m_entries.end() || insert_loc->first != sec_name, "duplicate key: " << sec_name);
+ sec.m_entries.emplace_hint(insert_loc, std::move(sec_name), load_storage_entry());
}
}
inline