31#ifndef ETL_REFERENCE_FLAT_SET_INCLUDED
32#define ETL_REFERENCE_FLAT_SET_INCLUDED
60 flat_set_exception(string_type reason_, string_type file_name_, numeric_type line_number_)
61 :
exception(reason_, file_name_, line_number_)
70 class flat_set_full :
public flat_set_exception
74 flat_set_full(string_type file_name_, numeric_type line_number_)
75 : flat_set_exception(ETL_ERROR_TEXT(
"flat_set:full", ETL_REFERENCE_FLAT_SET_FILE_ID
"A"), file_name_, line_number_)
84 class flat_set_iterator :
public flat_set_exception
88 flat_set_iterator(string_type file_name_, numeric_type line_number_)
89 : flat_set_exception(ETL_ERROR_TEXT(
"flat_set:iterator", ETL_REFERENCE_FLAT_SET_FILE_ID
"B"), file_name_, line_number_)
100 template <
typename T,
typename TKeyCompare = etl::less<T> >
106 typedef T value_type;
107 typedef TKeyCompare key_compare;
108 typedef value_type& reference;
109 typedef const value_type& const_reference;
110 typedef value_type* pointer;
111 typedef const value_type* const_pointer;
112 typedef size_t size_type;
121 class iterator :
public etl::iterator<ETL_OR_STD::bidirectional_iterator_tag, value_type>
125 friend class ireference_flat_set;
126 friend class const_iterator;
130 iterator(
typename lookup_t::iterator ilookup_)
135 iterator(
const iterator& other)
136 : ilookup(other.ilookup)
140 iterator& operator=(
const iterator& other)
142 ilookup = other.ilookup;
146 iterator& operator++()
152 iterator operator++(
int)
154 iterator temp(*
this);
159 iterator& operator--()
165 iterator operator--(
int)
167 iterator temp(*
this);
172 reference operator*()
const
177 pointer operator&()
const
182 pointer operator->()
const
187 friend bool operator==(
const iterator& lhs,
const iterator& rhs)
189 return lhs.ilookup == rhs.ilookup;
192 friend bool operator!=(
const iterator& lhs,
const iterator& rhs)
194 return !(lhs == rhs);
199 typename lookup_t::iterator ilookup;
203 class const_iterator :
public etl::iterator<ETL_OR_STD::bidirectional_iterator_tag, const value_type>
207 friend class ireference_flat_set;
211 const_iterator(
typename lookup_t::const_iterator ilookup_)
217 : ilookup(other.ilookup)
221 const_iterator(
const const_iterator& other)
222 : ilookup(other.ilookup)
226 const_iterator& operator=(
const iterator& other)
228 ilookup = other.ilookup;
232 const_iterator& operator=(
const const_iterator& other)
234 ilookup = other.ilookup;
238 const_iterator& operator++()
244 const_iterator operator++(
int)
246 const_iterator temp(*
this);
251 const_iterator& operator--()
257 const_iterator operator--(
int)
259 const_iterator temp(*
this);
264 const_reference operator*()
const
269 const_pointer operator&()
const
274 const_pointer operator->()
const
279 friend bool operator==(
const const_iterator& lhs,
const const_iterator& rhs)
281 return lhs.ilookup == rhs.ilookup;
284 friend bool operator!=(
const const_iterator& lhs,
const const_iterator& rhs)
286 return !(lhs == rhs);
291 typename lookup_t::const_iterator ilookup;
300 typedef ETL_OR_STD::reverse_iterator<iterator> reverse_iterator;
301 typedef ETL_OR_STD::reverse_iterator<const_iterator> const_reverse_iterator;
302 typedef typename etl::iterator_traits<iterator>::difference_type difference_type;
310 return iterator(lookup.begin());
319 return const_iterator(lookup.begin());
328 return iterator(lookup.end());
335 const_iterator
end()
const
337 return const_iterator(lookup.end());
346 return const_iterator(lookup.cbegin());
355 return const_iterator(lookup.cend());
365 return reverse_iterator(lookup.rbegin());
376 return const_reverse_iterator(lookup.rbegin());
385 return reverse_iterator(lookup.rend());
393 const_reverse_iterator
rend()
const
395 return const_reverse_iterator(lookup.rend());
406 return const_reverse_iterator(lookup.crbegin());
414 const_reverse_iterator
crend()
const
416 return const_reverse_iterator(lookup.crend());
428 template <
typename TIterator>
429 void assign(TIterator first, TIterator last)
431#if ETL_IS_DEBUG_BUILD
432 difference_type d = etl::distance(first, last);
438 while (first != last)
451 ETL_OR_STD::pair<iterator, bool>
insert(reference value)
465 iterator
insert(const_iterator , reference value)
467 return insert(value).first;
478 template <
class TIterator>
479 void insert(TIterator first, TIterator last)
481 while (first != last)
495 iterator i_element =
find(key);
497 if (i_element ==
end())
503 lookup.erase(i_element.ilookup);
510 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
511 size_t erase(K&& key)
515 if (i_element ==
end())
521 lookup.
erase(i_element.ilookup);
533 return lookup.erase(i_element.ilookup);
540 iterator
erase(const_iterator i_element)
542 return lookup.erase(i_element.ilookup);
552 iterator
erase(const_iterator first, const_iterator last)
554 return lookup.erase(first.ilookup, last.ilookup);
572 iterator itr = etl::lower_bound(
begin(),
end(), key, compare);
576 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
591 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
598 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
617 const_iterator
find(parameter_t key)
const
619 const_iterator itr = etl::lower_bound(
begin(),
end(), key, compare);
623 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
638 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
645 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
666 return (
find(key) ==
end()) ? 0 : 1;
671 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
672 size_t count(
const K& key)
const
674 return (
find(key) ==
end()) ? 0 : 1;
685 return etl::lower_bound(
begin(),
end(), key, compare);
690 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
704 return etl::lower_bound(
cbegin(),
cend(), key, compare);
709 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
723 return etl::upper_bound(
begin(),
end(), key, compare);
728 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
742 return etl::upper_bound(
cbegin(),
cend(), key, compare);
747 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
761 return etl::equal_range(
begin(),
end(), key, compare);
766 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
767 ETL_OR_STD::pair<iterator, iterator>
equal_range(
const K& key)
778 ETL_OR_STD::pair<const_iterator, const_iterator>
equal_range(parameter_t key)
const
780 return etl::upper_bound(
cbegin(),
cend(), key, compare);
785 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
786 ETL_OR_STD::pair<const_iterator, const_iterator>
equal_range(
const K& key)
const
802 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
815 return lookup.size();
824 return lookup.empty();
833 return lookup.full();
842 return lookup.capacity();
851 return lookup.max_size();
860 return lookup.available();
878 ETL_OR_STD::pair<iterator, bool>
insert_at(iterator i_element, reference value)
880 ETL_OR_STD::pair<iterator, bool> result(
end(),
false);
882 if (i_element ==
end())
887 lookup.push_back(&value);
888 result.first = --
end();
889 result.second =
true;
894 result.first = i_element;
897 if (compare(value, *i_element) || compare(*i_element, value))
901 lookup.insert(i_element.ilookup, &value);
902 result.second =
true;
922#if defined(ETL_POLYMORPHIC_REFERENCE_FLAT_SET) || defined(ETL_POLYMORPHIC_CONTAINERS)
939 template <
typename TKey, const
size_t MAX_SIZE_,
typename TKeyCompare = etl::less<TKey> >
944 static ETL_CONSTANT
size_t MAX_SIZE = MAX_SIZE_;
946 using typename ireference_flat_set<TKey, TKeyCompare>::value_type;
971 template <
typename TIterator>
992 template <
typename TKey, const
size_t MAX_SIZE_,
typename TCompare>
993 ETL_CONSTANT
size_t reference_flat_set<TKey, MAX_SIZE_, TCompare>::MAX_SIZE;
998#if ETL_USING_CPP17 && ETL_HAS_INITIALIZER_LIST
999 template <
typename... T>
1000 reference_flat_set(T...) -> reference_flat_set<etl::nth_type_t<0, T...>,
sizeof...(T)>;
1006#if ETL_USING_CPP11 && ETL_HAS_INITIALIZER_LIST
1007 template <
typename TKey,
typename TKeyCompare = etl::less<TKey>,
typename... T>
1008 constexpr auto make_reference_flat_set(T&&... keys) ->
etl::reference_flat_set<TKey,
sizeof...(T), TKeyCompare>
1010 return {etl::forward<T>(keys)...};
1021 template <
typename T,
typename TKeyCompare>
1034 template <
typename T,
typename TKeyCompare>
1037 return !(lhs == rhs);
Definition reference_flat_set.h:71
Definition reference_flat_set.h:122
Definition reference_flat_set.h:102
const_iterator lower_bound(parameter_t key) const
Definition reference_flat_set.h:702
~ireference_flat_set()
Destructor.
Definition reference_flat_set.h:931
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
ETL_OR_STD::pair< iterator, bool > insert(reference value)
Definition reference_flat_set.h:451
const_iterator begin() const
Definition reference_flat_set.h:317
iterator upper_bound(parameter_t key)
Definition reference_flat_set.h:721
const_iterator find(parameter_t key) const
Definition reference_flat_set.h:617
iterator erase(iterator i_element)
Definition reference_flat_set.h:531
void assign(TIterator first, TIterator last)
Definition reference_flat_set.h:429
iterator erase(const_iterator first, const_iterator last)
Definition reference_flat_set.h:552
const_reverse_iterator rend() const
Definition reference_flat_set.h:393
const_reverse_iterator crbegin() const
Definition reference_flat_set.h:404
const_iterator end() const
Definition reference_flat_set.h:335
iterator begin()
Definition reference_flat_set.h:308
size_t erase(parameter_t key)
Definition reference_flat_set.h:493
bool contains(parameter_t key) const
Check if the set contains the key.
Definition reference_flat_set.h:795
iterator insert(const_iterator, reference value)
Definition reference_flat_set.h:465
iterator end()
Definition reference_flat_set.h:326
ETL_OR_STD::pair< const_iterator, const_iterator > equal_range(parameter_t key) const
Definition reference_flat_set.h:778
ETL_OR_STD::pair< iterator, iterator > equal_range(parameter_t key)
Definition reference_flat_set.h:759
const_iterator upper_bound(parameter_t key) const
Definition reference_flat_set.h:740
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
const_reverse_iterator rbegin() const
Definition reference_flat_set.h:374
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
ireference_flat_set(lookup_t &lookup_)
Constructor.
Definition reference_flat_set.h:868
size_t count(parameter_t key) const
Definition reference_flat_set.h:664
void insert(TIterator first, TIterator last)
Definition reference_flat_set.h:479
bool full() const
Definition reference_flat_set.h:831
void clear()
Clears the reference_flat_set.
Definition reference_flat_set.h:560
iterator erase(const_iterator i_element)
Definition reference_flat_set.h:540
iterator lower_bound(parameter_t key)
Definition reference_flat_set.h:683
reverse_iterator rend()
Definition reference_flat_set.h:383
Definition reference_flat_set.h:941
reference_flat_set(TIterator first, TIterator last)
Definition reference_flat_set.h:972
reference_flat_set(const reference_flat_set &other)
Copy constructor.
Definition reference_flat_set.h:959
reference_flat_set()
Constructor.
Definition reference_flat_set.h:951
~reference_flat_set()
Destructor.
Definition reference_flat_set.h:981
ETL_CONSTEXPR14 bool operator!=(const etl::bitset< Active_Bits, TElement > &lhs, const etl::bitset< Active_Bits, TElement > &rhs) ETL_NOEXCEPT
Definition bitset_new.h:2529
#define ETL_ASSERT(b, e)
Definition error_handler.h:511
ETL_EXCEPTION_CONSTEXPR exception(string_type reason_, string_type, numeric_type)
Constructor.
Definition exception.h:81
ETL_CONSTEXPR17 etl::enable_if<!etl::is_same< T, etl::nullptr_t >::value, T >::type * addressof(T &t)
Definition addressof.h:52
iterator erase(iterator i_element)
Definition vector.h:911
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
etl::conditional< etl::is_fundamental< T >::value||etl::is_pointer< T >::value, T, constT & >::type type
By default fundamental and pointer types are passed by value.
Definition parameter_type.h:46