summary refs log tree commit diff
path: root/include
diff options
context:
space:
mode:
authorKonstantinos Sideris <sideris.konstantin@gmail.com>2018-04-27 18:19:43 +0300
committerKonstantinos Sideris <sideris.konstantin@gmail.com>2018-04-27 18:19:43 +0300
commitc971602b2def753f46d41c9e3b6f2a2d38cdbf68 (patch)
tree005a451b3677b77450cd168108f110066a16f477 /include
parentUpdate matrix-struct (diff)
downloadnheko-c971602b2def753f46d41c9e3b6f2a2d38cdbf68.tar.xz
Add remove_if for maps
Diffstat (limited to 'include')
-rw-r--r--include/Utils.h13
1 files changed, 13 insertions, 0 deletions
diff --git a/include/Utils.h b/include/Utils.h

index 5586a479..c3b30084 100644 --- a/include/Utils.h +++ b/include/Utils.h
@@ -55,6 +55,19 @@ scaleDown(uint64_t max_width, uint64_t max_height, const ImageType &source) final_width, final_height, Qt::IgnoreAspectRatio, Qt::SmoothTransformation); } +//! Delete items in a container based on a predicate. +template<typename ContainerT, typename PredicateT> +void +erase_if(ContainerT &items, const PredicateT &predicate) +{ + for (auto it = items.begin(); it != items.end();) { + if (predicate(*it)) + it = items.erase(it); + else + ++it; + } +}; + //! Calculate the Levenshtein distance between two strings with character skipping. int levenshtein_distance(const std::string &s1, const std::string &s2);