From 4ce8cc70d95740bc2faf7742ac106d50e8a79cc6 Mon Sep 17 00:00:00 2001 From: Phil Willoughby Date: Mon, 5 Jun 2017 10:58:29 -0700 Subject: [PATCH] Make StringKeyed* more complete Summary: Add `count()` and `swap()` methods. Ensure that `operator==` works. Reviewed By: yfeldblum Differential Revision: D5169393 fbshipit-source-id: a8025f6fdf251e38b0d2f27733d18967a55c6a15 --- folly/experimental/StringKeyedMap.h | 11 +++++++++++ folly/experimental/StringKeyedSet.h | 11 +++++++++++ folly/experimental/StringKeyedUnorderedMap.h | 9 +++++++-- folly/experimental/StringKeyedUnorderedSet.h | 10 ++++++++-- 4 files changed, 37 insertions(+), 4 deletions(-) diff --git a/folly/experimental/StringKeyedMap.h b/folly/experimental/StringKeyedMap.h index 3024b33f..d8b822c7 100644 --- a/folly/experimental/StringKeyedMap.h +++ b/folly/experimental/StringKeyedMap.h @@ -131,6 +131,12 @@ public: using Base::crbegin; using Base::crend; + bool operator==(StringKeyedMap const& other) const { + Base const& lhs = *this; + Base const& rhs = static_cast(other); + return lhs == rhs; + } + // no need for copy/move overload as StringPiece is small struct mapped_type& operator[](StringPiece key) { auto it = find(key); @@ -144,6 +150,7 @@ public: using Base::at; using Base::find; + using Base::count; using Base::lower_bound; using Base::upper_bound; @@ -190,6 +197,10 @@ public: Base::clear(); } + void swap(StringKeyedMap& other) & { + return Base::swap(other); + } + ~StringKeyedMap() { // Here we assume that map doesn't use keys in destructor for (auto& it : *this) { diff --git a/folly/experimental/StringKeyedSet.h b/folly/experimental/StringKeyedSet.h index f2b3af84..2b3f8f3e 100644 --- a/folly/experimental/StringKeyedSet.h +++ b/folly/experimental/StringKeyedSet.h @@ -127,9 +127,16 @@ public: using Base::cbegin; using Base::cend; using Base::find; + using Base::count; using Base::lower_bound; using Base::upper_bound; + bool operator==(StringKeyedSetBase const& other) const { + Base const& lhs = *this; + Base const& rhs = static_cast(other); + return lhs == rhs; + } + template std::pair emplace(Args&&... args) { auto key = StringPiece(std::forward(args)...); @@ -173,6 +180,10 @@ public: using Base::get_allocator; + void swap(StringKeyedSetBase& other) & { + return Base::swap(other); + } + ~StringKeyedSetBase() { // Here we assume that set doesn't use keys in destructor for (auto it : *this) { diff --git a/folly/experimental/StringKeyedUnorderedMap.h b/folly/experimental/StringKeyedUnorderedMap.h index fe2fb411..7099332a 100644 --- a/folly/experimental/StringKeyedUnorderedMap.h +++ b/folly/experimental/StringKeyedUnorderedMap.h @@ -151,11 +151,16 @@ public: using Base::cbegin; using Base::cend; - bool operator==(const StringKeyedUnorderedMap& rhs) { - const Base& lhs = *this; + bool operator==(StringKeyedUnorderedMap const& other) const { + Base const& lhs = *this; + Base const& rhs = static_cast(other); return lhs == rhs; } + void swap(StringKeyedUnorderedMap& other) & { + return Base::swap(other); + } + // No need for copy/move overload as StringPiece is small struct. mapped_type& operator[](StringPiece key) { auto it = find(key); diff --git a/folly/experimental/StringKeyedUnorderedSet.h b/folly/experimental/StringKeyedUnorderedSet.h index a72040ad..0956bacf 100644 --- a/folly/experimental/StringKeyedUnorderedSet.h +++ b/folly/experimental/StringKeyedUnorderedSet.h @@ -160,9 +160,11 @@ public: using Base::cbegin; using Base::cend; using Base::find; + using Base::count; - bool operator==(const BasicStringKeyedUnorderedSet& rhs) const { - const Base& lhs = *this; + bool operator==(const BasicStringKeyedUnorderedSet& other) const { + Base const& lhs = *this; + Base const& rhs = static_cast(other); return lhs == rhs; } @@ -214,6 +216,10 @@ public: using Base::bucket_size; using Base::bucket; + void swap(BasicStringKeyedUnorderedSet& other) & { + return Base::swap(other); + } + ~BasicStringKeyedUnorderedSet() { // Here we assume that unordered_set doesn't use keys in destructor for (auto& it : *this) { -- 2.34.1