31#ifndef ETL_FLAT_SET_INCLUDED
32#define ETL_FLAT_SET_INCLUDED
60 template <
typename T,
typename TKeyCompare = etl::less<T> >
66 typedef typename refset_t::lookup_t lookup_t;
69 typedef const T& key_parameter_t;
75 typedef TKeyCompare key_compare;
76 typedef value_type& reference;
77 typedef const value_type& const_reference;
79 typedef value_type&& rvalue_reference;
81 typedef value_type* pointer;
82 typedef const value_type* const_pointer;
83 typedef size_t size_type;
85 typedef typename refset_t::iterator iterator;
86 typedef typename refset_t::const_iterator const_iterator;
88 typedef ETL_OR_STD::reverse_iterator<iterator> reverse_iterator;
89 typedef ETL_OR_STD::reverse_iterator<const_iterator> const_reverse_iterator;
90 typedef typename etl::iterator_traits<iterator>::difference_type difference_type;
125 const_iterator
end()
const
180 const_reverse_iterator
rend()
const
199 const_reverse_iterator
crend()
const
212 template <
typename TIterator>
213 void assign(TIterator first, TIterator last)
215#if ETL_IS_DEBUG_BUILD
216 difference_type d = etl::distance(first, last);
222 while (first != last)
235 ETL_OR_STD::pair<iterator, bool>
insert(const_reference value)
239 ETL_OR_STD::pair<iterator, bool> result(i_element,
false);
242 if ((i_element ==
end()) || compare(value, *i_element))
246 value_type* pvalue = storage.allocate<value_type>();
247 ::new (pvalue) value_type(value);
248 ETL_INCREMENT_DEBUG_COUNT;
262 ETL_OR_STD::pair<iterator, bool>
insert(rvalue_reference value)
266 ETL_OR_STD::pair<iterator, bool> result(i_element,
false);
269 if ((i_element ==
end()) ||
compare(value, *i_element))
275 ETL_INCREMENT_DEBUG_COUNT;
290 iterator
insert(const_iterator , const_reference value)
292 return insert(value).first;
305 return insert(etl::move(value)).first;
317 template <
class TIterator>
318 void insert(TIterator first, TIterator last)
320 while (first != last)
330 ETL_OR_STD::pair<iterator, bool>
emplace(const_reference value)
338#if ETL_USING_CPP11 && ETL_NOT_USING_STLPORT && !defined(ETL_FLAT_SET_FORCE_CPP03_IMPLEMENTATION)
339 template <
typename... Args>
340 ETL_OR_STD::pair<iterator, bool>
emplace(Args&&... args)
344 ETL_OR_STD::pair<iterator, bool> result;
348 ::new (pvalue)
value_type(etl::forward<Args>(args)...);
353 if ((i_element ==
end()) ||
compare(*pvalue, *i_element))
355 ETL_INCREMENT_DEBUG_COUNT;
361 pvalue->~value_type();
363 result = ETL_OR_STD::pair<iterator, bool>(
end(),
false);
376 ETL_OR_STD::pair<iterator, bool> result;
379 value_type* pvalue = storage.allocate<value_type>();
380 ::new (pvalue) value_type();
385 if ((i_element ==
end()) || compare(*pvalue, *i_element))
387 ETL_INCREMENT_DEBUG_COUNT;
393 pvalue->~value_type();
394 storage.release(pvalue);
395 result = ETL_OR_STD::pair<iterator, bool>(
end(),
false);
404 template <
typename T1>
405 ETL_OR_STD::pair<iterator, bool>
emplace(
const T1& value1)
409 ETL_OR_STD::pair<iterator, bool> result;
412 value_type* pvalue = storage.allocate<value_type>();
413 ::new (pvalue) value_type(value1);
418 if ((i_element ==
end()) || compare(*pvalue, *i_element))
420 ETL_INCREMENT_DEBUG_COUNT;
426 pvalue->~value_type();
427 storage.release(pvalue);
428 result = ETL_OR_STD::pair<iterator, bool>(
end(),
false);
437 template <
typename T1,
typename T2>
438 ETL_OR_STD::pair<iterator, bool>
emplace(
const T1& value1,
const T2& value2)
442 ETL_OR_STD::pair<iterator, bool> result;
445 value_type* pvalue = storage.allocate<value_type>();
446 ::new (pvalue) value_type(value1, value2);
451 if ((i_element ==
end()) || compare(*pvalue, *i_element))
453 ETL_INCREMENT_DEBUG_COUNT;
459 pvalue->~value_type();
460 storage.release(pvalue);
461 result = ETL_OR_STD::pair<iterator, bool>(
end(),
false);
470 template <
typename T1,
typename T2,
typename T3>
471 ETL_OR_STD::pair<iterator, bool>
emplace(
const T1& value1,
const T2& value2,
const T3& value3)
475 ETL_OR_STD::pair<iterator, bool> result;
478 value_type* pvalue = storage.allocate<value_type>();
479 ::new (pvalue) value_type(value1, value2, value3);
484 if ((i_element ==
end()) || compare(*pvalue, *i_element))
486 ETL_INCREMENT_DEBUG_COUNT;
492 pvalue->~value_type();
493 storage.release(pvalue);
494 result = ETL_OR_STD::pair<iterator, bool>(
end(),
false);
503 template <
typename T1,
typename T2,
typename T3,
typename T4>
504 ETL_OR_STD::pair<iterator, bool>
emplace(
const T1& value1,
const T2& value2,
const T3& value3,
const T4& value4)
508 ETL_OR_STD::pair<iterator, bool> result;
511 value_type* pvalue = storage.allocate<value_type>();
512 ::new (pvalue) value_type(value1, value2, value3, value4);
517 if ((i_element ==
end()) || compare(*pvalue, *i_element))
519 ETL_INCREMENT_DEBUG_COUNT;
525 pvalue->~value_type();
526 storage.release(pvalue);
527 result = ETL_OR_STD::pair<iterator, bool>(
end(),
false);
541 iterator i_element =
find(key);
543 if (i_element ==
end())
552 ETL_DECREMENT_DEBUG_COUNT;
559 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
560 size_t erase(K&& key)
564 if (i_element ==
end())
573 ETL_DECREMENT_DEBUG_COUNT;
587 ETL_DECREMENT_DEBUG_COUNT;
595 iterator
erase(const_iterator i_element)
599 ETL_DECREMENT_DEBUG_COUNT;
610 iterator
erase(const_iterator first, const_iterator last)
612 const_iterator itr = first;
619 ETL_DECREMENT_DEBUG_COUNT;
630 if ETL_IF_CONSTEXPR (etl::is_trivially_destructible<value_type>::value)
632 storage.release_all();
636 iterator itr =
begin();
643 ETL_DECREMENT_DEBUG_COUNT;
647 ETL_RESET_DEBUG_COUNT;
656 iterator
find(key_parameter_t key)
663 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
675 const_iterator
find(key_parameter_t key)
const
682 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
694 size_t count(key_parameter_t key)
const
701 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
702 size_t count(
const K& key)
const
720 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
739 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
758 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
777 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
789 ETL_OR_STD::pair<iterator, iterator>
equal_range(key_parameter_t key)
796 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
797 ETL_OR_STD::pair<iterator, iterator>
equal_range(
const K& key)
808 ETL_OR_STD::pair<const_iterator, const_iterator>
equal_range(key_parameter_t key)
const
815 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
816 ETL_OR_STD::pair<const_iterator, const_iterator>
equal_range(
const K& key)
const
832 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
858 move_container(etl::move(rhs));
940 etl::iflat_set<T, TKeyCompare>::iterator first = rhs.begin();
941 etl::iflat_set<T, TKeyCompare>::iterator last = rhs.end();
944 while (first != last)
946 typename etl::iflat_set<T, TKeyCompare>::iterator temp = first;
949 this->
insert(etl::move(*first));
966 ETL_DECLARE_DEBUG_COUNT;
971#if defined(ETL_POLYMORPHIC_FLAT_SET) || defined(ETL_POLYMORPHIC_CONTAINERS)
991 template <
typename T,
typename TKeyCompare>
1004 template <
typename T,
typename TKeyCompare>
1007 return !(lhs == rhs);
1017 template <
typename T, const
size_t MAX_SIZE_,
typename TCompare = etl::less<T> >
1022 static ETL_CONSTANT
size_t MAX_SIZE = MAX_SIZE_;
1050 this->move_container(etl::move(other));
1061 template <
typename TIterator>
1065 this->
assign(first, last);
1068#if ETL_HAS_INITIALIZER_LIST
1072 flat_set(std::initializer_list<T> init)
1075 this->
assign(init.begin(), init.end());
1108 this->move_container(etl::move(rhs));
1117 typedef typename etl::iflat_set<T, TCompare>::value_type node_t;
1120 etl::pool<node_t, MAX_SIZE> storage;
1123 etl::vector<node_t*, MAX_SIZE> lookup;
1126 template <
typename T, const
size_t MAX_SIZE_,
typename TCompare>
1127 ETL_CONSTANT
size_t flat_set<T, MAX_SIZE_, TCompare>::MAX_SIZE;
1132#if ETL_USING_CPP17 && ETL_HAS_INITIALIZER_LIST
1133 template <
typename... T>
1140#if ETL_USING_CPP11 && ETL_HAS_INITIALIZER_LIST
1141 template <
typename TKey,
typename TKeyCompare = etl::less<TKey>,
typename... T>
1142 constexpr auto make_flat_set(T&&... keys) -> etl::flat_set<TKey,
sizeof...(T), TKeyCompare>
1144 return {etl::forward<T>(keys)...};
Definition reference_flat_set.h:71
Definition reference_flat_set.h:102
size_type capacity() const
Definition reference_flat_set.h:840
ETL_OR_STD::pair< iterator, bool > insert_at(iterator i_element, reference value)
Definition reference_flat_set.h:878
size_t available() const
Definition reference_flat_set.h:858
iterator upper_bound(parameter_t key)
Definition reference_flat_set.h:721
const_reverse_iterator crbegin() const
Definition reference_flat_set.h:404
iterator begin()
Definition reference_flat_set.h:308
size_t erase(parameter_t key)
Definition reference_flat_set.h:493
iterator end()
Definition reference_flat_set.h:326
ETL_OR_STD::pair< iterator, iterator > equal_range(parameter_t key)
Definition reference_flat_set.h:759
const_iterator cend() const
Definition reference_flat_set.h:353
const_iterator cbegin() const
Definition reference_flat_set.h:344
iterator find(parameter_t key)
Definition reference_flat_set.h:570
size_type max_size() const
Definition reference_flat_set.h:849
const_reverse_iterator crend() const
Definition reference_flat_set.h:414
bool empty() const
Definition reference_flat_set.h:822
size_type size() const
Definition reference_flat_set.h:813
reverse_iterator rbegin()
Definition reference_flat_set.h:363
size_t count(parameter_t key) const
Definition reference_flat_set.h:664
bool full() const
Definition reference_flat_set.h:831
void clear()
Definition reference_flat_set.h:560
iterator lower_bound(parameter_t key)
Definition reference_flat_set.h:683
reverse_iterator rend()
Definition reference_flat_set.h:383
#define ETL_ASSERT(b, e)
Definition error_handler.h:511
const_iterator cbegin() const
Definition flat_set.h:134
iterator insert(const_iterator, const_reference value)
Definition flat_set.h:290
~iflat_set()
Destructor.
Definition flat_set.h:980
iterator upper_bound(key_parameter_t key)
Definition flat_set.h:751
size_t available() const
Definition flat_set.h:913
flat_set()
Constructor.
Definition flat_set.h:1027
size_t erase(key_parameter_t key)
Definition flat_set.h:539
iterator begin()
Definition flat_set.h:98
iflat_set(lookup_t &lookup_, storage_t &storage_)
Constructor.
Definition flat_set.h:923
const_iterator begin() const
Definition flat_set.h:107
const_reverse_iterator crbegin() const
Definition flat_set.h:190
iterator erase(iterator i_element)
Definition flat_set.h:583
ETL_OR_STD::pair< iterator, bool > emplace(const T1 &value1)
Emplaces a value to the set.
Definition flat_set.h:405
size_type max_size() const
Definition flat_set.h:904
iterator find(key_parameter_t key)
Definition flat_set.h:656
ETL_OR_STD::pair< iterator, iterator > equal_range(key_parameter_t key)
Definition flat_set.h:789
size_type capacity() const
Definition flat_set.h:895
ETL_OR_STD::pair< iterator, bool > emplace(const T1 &value1, const T2 &value2, const T3 &value3, const T4 &value4)
Emplaces a value to the set.
Definition flat_set.h:504
size_t count(key_parameter_t key) const
Definition flat_set.h:694
ETL_OR_STD::pair< iterator, bool > emplace(const_reference value)
Emplaces a value to the set.
Definition flat_set.h:330
iterator erase(const_iterator first, const_iterator last)
Definition flat_set.h:610
iterator lower_bound(key_parameter_t key)
Definition flat_set.h:713
ETL_OR_STD::pair< iterator, bool > emplace()
Emplaces a value to the set.
Definition flat_set.h:372
bool empty() const
Definition flat_set.h:877
const_iterator find(key_parameter_t key) const
Definition flat_set.h:675
~flat_set()
Destructor.
Definition flat_set.h:1082
iflat_set & operator=(const iflat_set &rhs)
Assignment operator.
Definition flat_set.h:842
const_iterator end() const
Definition flat_set.h:125
bool full() const
Definition flat_set.h:886
iterator end()
Definition flat_set.h:116
bool contains(key_parameter_t key) const
Check if the map contains the key.
Definition flat_set.h:825
iterator erase(const_iterator i_element)
Definition flat_set.h:595
ETL_OR_STD::pair< iterator, bool > insert(const_reference value)
Definition flat_set.h:235
const_reverse_iterator rbegin() const
Definition flat_set.h:162
ETL_OR_STD::pair< iterator, bool > emplace(const T1 &value1, const T2 &value2)
Emplaces a value to the set.
Definition flat_set.h:438
void insert(TIterator first, TIterator last)
Definition flat_set.h:318
const_reverse_iterator crend() const
Definition flat_set.h:199
void assign(TIterator first, TIterator last)
Definition flat_set.h:213
reverse_iterator rend()
Definition flat_set.h:171
flat_set & operator=(const flat_set &rhs)
Assignment operator.
Definition flat_set.h:1090
flat_set(const flat_set &other)
Copy constructor.
Definition flat_set.h:1035
size_type size() const
Definition flat_set.h:868
const_iterator lower_bound(key_parameter_t key) const
Definition flat_set.h:732
reverse_iterator rbegin()
Definition flat_set.h:152
const_iterator upper_bound(key_parameter_t key) const
Definition flat_set.h:770
const_reverse_iterator rend() const
Definition flat_set.h:180
const_iterator cend() const
Definition flat_set.h:143
ETL_OR_STD::pair< const_iterator, const_iterator > equal_range(key_parameter_t key) const
Definition flat_set.h:808
ETL_OR_STD::pair< iterator, bool > emplace(const T1 &value1, const T2 &value2, const T3 &value3)
Emplaces a value to the set.
Definition flat_set.h:471
flat_set(TIterator first, TIterator last)
Definition flat_set.h:1062
void clear()
Clears the flat_set.
Definition flat_set.h:628
Definition flat_set.h:1019
ETL_CONSTEXPR17 etl::enable_if<!etl::is_same< T, etl::nullptr_t >::value, T >::type * addressof(T &t)
Definition addressof.h:52
etl::enable_if< etl::is_trivially_destructible< T >::value, void >::type destroy_at(T *)
Definition memory.h:1511
T * allocate()
Definition ipool.h:333
void release(const void *const p_object)
Definition ipool.h:460
bitset_ext
Definition absolute.h:40
ETL_CONSTEXPR14 bool operator==(const etl::array< T, SIZE > &lhs, const etl::array< T, SIZE > &rhs)
Definition array.h:1081
ETL_CONSTEXPR14 bool operator!=(const etl::array< T, SIZE > &lhs, const etl::array< T, SIZE > &rhs)
Definition array.h:1093
iterator
Definition iterator.h:424