From f73037a520c032705f4d240cac679436115b2ff4 Mon Sep 17 00:00:00 2001 From: Borislav Stanimirov Date: Sat, 24 Aug 2024 17:49:22 +0300 Subject: [PATCH] [transparent_umap] minor tweaks, still wip --- include/itlib/transparent_umap.hpp | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/include/itlib/transparent_umap.hpp b/include/itlib/transparent_umap.hpp index a861e45..a96021f 100644 --- a/include/itlib/transparent_umap.hpp +++ b/include/itlib/transparent_umap.hpp @@ -1,7 +1,7 @@ // itlib-transparent_umap v1.00 // -// A a really transparent unordered map which includes the C++26 features -// they forgot to add in C++20. +// A a really transparent unordered map which includes the C++23 and C++26 +// features they forgot to add in C++20. // // SPDX-License-Identifier: MIT // MIT License: @@ -36,8 +36,8 @@ // // Simply include this file wherever you need. // It defines the class itlib::transparent_umap which is is essentially a -// std::unordered_map which includes the C++26 features they forgot to add in -// C++20. Namely tansparent-aware overloads of: +// std::unordered_map which includes the C++23 and 26 features they forgot to +// add in C++20. Namely tansparent-aware overloads of: // // * try_emplace() // * operator[] @@ -75,11 +75,11 @@ template < typename Alloc = std::allocator> > class transparent_umap : public std::unordered_map { public: - using base = std::unordered_map; - using base::unordered_map; + using super = std::unordered_map; + using super::unordered_map; - using iterator = base::iterator; - using const_iterator = base::const_iterator; + using iterator = super::iterator; + using const_iterator = super::const_iterator; // enable if transparent template @@ -96,7 +96,7 @@ template < , R >; - using base::try_emplace; + using super::try_emplace; template enable_if_tr_c> try_emplace(K&& key, Args&&... args) { @@ -107,19 +107,20 @@ template < template enable_if_tr> try_emplace(const_iterator hint, K&& key, Args&&... args) { + // what does the hint even mean? auto f = this->find(key); if (f != this->end()) return { f, false }; return this->emplace_hint(hint, std::forward(key), T(std::forward(args)...)); } - using base::operator[]; + using super::operator[]; template enable_if_tr_c operator[](K&& key) { return this->try_emplace(std::forward(key)).first->second; } - using base::at; + using super::at; template enable_if_tr at(const K& key) {