31#ifndef ETL_REFERENCE_FLAT_MULTISET_INCLUDED
32#define ETL_REFERENCE_FLAT_MULTISET_INCLUDED
60 flat_multiset_exception(string_type reason_, string_type file_name_, numeric_type line_number_)
61 :
exception(reason_, file_name_, line_number_)
70 class flat_multiset_full :
public flat_multiset_exception
74 flat_multiset_full(string_type file_name_, numeric_type line_number_)
75 : flat_multiset_exception(ETL_ERROR_TEXT(
"flat_multiset:full", ETL_REFERENCE_FLAT_MULTISET_FILE_ID
"A"), file_name_, line_number_)
84 class flat_multiset_iterator :
public flat_multiset_exception
88 flat_multiset_iterator(string_type file_name_, numeric_type line_number_)
89 : flat_multiset_exception(ETL_ERROR_TEXT(
"flat_multiset:iterator", ETL_REFERENCE_FLAT_MULTISET_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_multiset;
129 iterator(
typename lookup_t::iterator ilookup_)
134 iterator(
const iterator& other)
135 : ilookup(other.ilookup)
139 iterator& operator=(
const iterator& other)
141 ilookup = other.ilookup;
145 iterator& operator++()
151 iterator operator++(
int)
153 iterator temp(*
this);
158 iterator& operator--()
164 iterator operator--(
int)
166 iterator temp(*
this);
171 reference operator*()
const
176 pointer operator&()
const
181 pointer operator->()
const
186 friend bool operator==(
const iterator& lhs,
const iterator& rhs)
188 return lhs.ilookup == rhs.ilookup;
191 friend bool operator!=(
const iterator& lhs,
const iterator& rhs)
193 return !(lhs == rhs);
198 typename lookup_t::iterator ilookup;
202 class const_iterator :
public etl::iterator<ETL_OR_STD::bidirectional_iterator_tag, const value_type>
206 friend class ireference_flat_multiset;
210 const_iterator(
typename lookup_t::const_iterator ilookup_)
216 : ilookup(other.ilookup)
220 const_iterator(
const const_iterator& other)
221 : ilookup(other.ilookup)
225 const_iterator& operator=(
const iterator& other)
227 ilookup = other.ilookup;
231 const_iterator& operator=(
const const_iterator& other)
233 ilookup = other.ilookup;
237 const_iterator& operator++()
243 const_iterator operator++(
int)
245 const_iterator temp(*
this);
250 const_iterator& operator--()
256 const_iterator operator--(
int)
258 const_iterator temp(*
this);
263 const_reference operator*()
const
268 const_pointer operator&()
const
273 const_pointer operator->()
const
278 friend bool operator==(
const const_iterator& lhs,
const const_iterator& rhs)
280 return lhs.ilookup == rhs.ilookup;
283 friend bool operator!=(
const const_iterator& lhs,
const const_iterator& rhs)
285 return !(lhs == rhs);
290 typename lookup_t::const_iterator ilookup;
299 typedef ETL_OR_STD::reverse_iterator<iterator> reverse_iterator;
300 typedef ETL_OR_STD::reverse_iterator<const_iterator> const_reverse_iterator;
301 typedef typename etl::iterator_traits<iterator>::difference_type difference_type;
309 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());
347 return const_iterator(lookup.cbegin());
356 return const_iterator(lookup.cend());
366 return reverse_iterator(lookup.rbegin());
377 return const_reverse_iterator(lookup.rbegin());
387 return reverse_iterator(lookup.rend());
396 const_reverse_iterator
rend()
const
398 return const_reverse_iterator(lookup.rend());
409 return const_reverse_iterator(lookup.crbegin());
418 const_reverse_iterator
crend()
const
420 return const_reverse_iterator(lookup.crend());
432 template <
typename TIterator>
433 void assign(TIterator first, TIterator last)
435#if ETL_IS_DEBUG_BUILD
436 difference_type d = etl::distance(first, last);
442 while (first != last)
455 ETL_OR_STD::pair<iterator, bool>
insert(value_type& value)
457 ETL_OR_STD::pair<iterator, bool> result(
end(),
false);
461 iterator i_element = etl::upper_bound(
begin(),
end(), value, compare);
463 if (i_element ==
end())
466 lookup.push_back(&value);
467 result.first = --
end();
468 result.second =
true;
473 lookup.insert(i_element.ilookup, &value);
474 result.first = i_element;
475 result.second =
true;
488 iterator
insert(const_iterator , value_type& value)
490 return insert(value).first;
501 template <
class TIterator>
502 void insert(TIterator first, TIterator last)
504 while (first != last)
518 ETL_OR_STD::pair<iterator, iterator> range =
equal_range(key);
520 if (range.first ==
end())
526 size_t d =
static_cast<size_t>(etl::distance(range.first, range.second));
527 erase(range.first, range.second);
534 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
535 size_t erase(K&& key)
537 ETL_OR_STD::pair<iterator, iterator> range =
equal_range(etl::forward<K>(key));
539 if (range.first ==
end())
545 size_t d =
static_cast<size_t>(etl::distance(range.first, range.second));
546 erase(range.first, range.second);
558 return lookup.erase(i_element.ilookup);
565 iterator
erase(const_iterator i_element)
567 return lookup.erase(i_element.ilookup);
577 iterator
erase(const_iterator first, const_iterator last)
579 return lookup.erase(first.ilookup, last.ilookup);
597 iterator itr = etl::lower_bound(
begin(),
end(), key, compare);
601 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
616 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
623 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
642 const_iterator
find(parameter_t key)
const
644 const_iterator itr = etl::lower_bound(
begin(),
end(), key, compare);
648 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
663 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
670 if (!key_compare()(*itr, key) && !key_compare()(key, *itr))
691 ETL_OR_STD::pair<const_iterator, const_iterator> range =
equal_range(key);
693 return static_cast<size_t>(etl::distance(range.first, range.second));
698 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
699 size_t count(
const K& key)
const
701 ETL_OR_STD::pair<const_iterator, const_iterator> range =
equal_range(key);
703 return static_cast<size_t>(etl::distance(range.first, range.second));
714 return etl::lower_bound(
begin(),
end(), key, compare);
719 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
733 return etl::lower_bound(
cbegin(),
cend(), key, compare);
738 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
752 return etl::upper_bound(
begin(),
end(), key, compare);
757 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
771 return etl::upper_bound(
cbegin(),
cend(), key, compare);
776 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
790 return etl::equal_range(
begin(),
end(), key, compare);
795 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
796 ETL_OR_STD::pair<iterator, iterator>
equal_range(
const K& key)
812 template <typename K, typename KC = TKeyCompare, etl::enable_if_t<comparator_is_transparent<KC>::value,
int> = 0>
824 ETL_OR_STD::pair<const_iterator, const_iterator>
equal_range(parameter_t key)
const
826 return etl::equal_range(
begin(),
end(), key, compare);
835 return lookup.size();
844 return lookup.empty();
853 return lookup.full();
862 return lookup.capacity();
871 return lookup.max_size();
880 return lookup.available();
898 ETL_OR_STD::pair<iterator, bool>
insert_at(iterator i_element, reference value)
900 ETL_OR_STD::pair<iterator, bool> result(
end(),
false);
902 if (i_element ==
end())
907 lookup.push_back(&value);
908 result.first = --
end();
909 result.second =
true;
914 result.first = i_element;
918 lookup.insert(i_element.ilookup, &value);
919 result.second =
true;
938#if defined(ETL_POLYMORPHIC_REFERENCE_FLAT_MULTISET) || defined(ETL_POLYMORPHIC_CONTAINERS)
955 template <
typename TKey, const
size_t MAX_SIZE_,
typename TKeyCompare = etl::less<TKey> >
960 static ETL_CONSTANT
size_t MAX_SIZE = MAX_SIZE_;
962 using typename ireference_flat_multiset<TKey, TKeyCompare>::value_type;
987 template <
typename TIterator>
1008 template <
typename TKey, const
size_t MAX_SIZE_,
typename TCompare>
1009 ETL_CONSTANT
size_t reference_flat_multiset<TKey, MAX_SIZE_, TCompare>::MAX_SIZE;
1014#if ETL_USING_CPP17 && ETL_HAS_INITIALIZER_LIST
1015 template <
typename... T>
1016 reference_flat_multiset(T...) -> reference_flat_multiset<etl::nth_type_t<0, T...>,
sizeof...(T)>;
1022#if ETL_USING_CPP11 && ETL_HAS_INITIALIZER_LIST
1023 template <
typename TKey,
typename TKeyCompare = etl::less<TKey>,
typename... T>
1026 return {etl::forward<T>(keys)...};
1037 template <
typename T,
typename TKeyCompare>
1050 template <
typename T,
typename TKeyCompare>
1053 return !(lhs == rhs);
Definition reference_flat_multiset.h:71
Definition reference_flat_multiset.h:122
Definition reference_flat_multiset.h:102
iterator upper_bound(parameter_t key)
Definition reference_flat_multiset.h:750
iterator erase(const_iterator first, const_iterator last)
Definition reference_flat_multiset.h:577
iterator erase(iterator i_element)
Definition reference_flat_multiset.h:556
iterator erase(const_iterator i_element)
Definition reference_flat_multiset.h:565
size_t count(parameter_t key) const
Definition reference_flat_multiset.h:689
const_iterator begin() const
Definition reference_flat_multiset.h:317
ETL_OR_STD::pair< iterator, bool > insert_at(iterator i_element, reference value)
Definition reference_flat_multiset.h:898
iterator begin()
Definition reference_flat_multiset.h:307
const_iterator find(parameter_t key) const
Definition reference_flat_multiset.h:642
~ireference_flat_multiset()
Destructor.
Definition reference_flat_multiset.h:947
const_iterator upper_bound(parameter_t key) const
Definition reference_flat_multiset.h:769
ireference_flat_multiset(lookup_t &lookup_)
Constructor.
Definition reference_flat_multiset.h:888
ETL_OR_STD::pair< const_iterator, const_iterator > equal_range(parameter_t key) const
Definition reference_flat_multiset.h:824
reverse_iterator rbegin()
Definition reference_flat_multiset.h:364
size_t erase(parameter_t key)
Definition reference_flat_multiset.h:516
bool empty() const
Definition reference_flat_multiset.h:842
const_iterator end() const
Definition reference_flat_multiset.h:335
reverse_iterator rend()
Definition reference_flat_multiset.h:385
iterator insert(const_iterator, value_type &value)
Definition reference_flat_multiset.h:488
ETL_OR_STD::pair< iterator, bool > insert(value_type &value)
Definition reference_flat_multiset.h:455
size_t available() const
Definition reference_flat_multiset.h:878
void insert(TIterator first, TIterator last)
Definition reference_flat_multiset.h:502
iterator find(parameter_t key)
Definition reference_flat_multiset.h:595
size_type size() const
Definition reference_flat_multiset.h:833
const_iterator lower_bound(parameter_t key) const
Definition reference_flat_multiset.h:731
bool contains(parameter_t key) const
Check if the map contains the key.
Definition reference_flat_multiset.h:805
bool full() const
Definition reference_flat_multiset.h:851
void clear()
Clears the reference_flat_multiset.
Definition reference_flat_multiset.h:585
iterator end()
Definition reference_flat_multiset.h:326
const_reverse_iterator rbegin() const
Definition reference_flat_multiset.h:375
iterator lower_bound(parameter_t key)
Definition reference_flat_multiset.h:712
ETL_OR_STD::pair< iterator, iterator > equal_range(parameter_t key)
Definition reference_flat_multiset.h:788
size_type capacity() const
Definition reference_flat_multiset.h:860
const_reverse_iterator crbegin() const
Definition reference_flat_multiset.h:407
const_reverse_iterator crend() const
Definition reference_flat_multiset.h:418
const_iterator cend() const
Definition reference_flat_multiset.h:354
const_reverse_iterator rend() const
Definition reference_flat_multiset.h:396
size_type max_size() const
Definition reference_flat_multiset.h:869
void assign(TIterator first, TIterator last)
Definition reference_flat_multiset.h:433
const_iterator cbegin() const
Definition reference_flat_multiset.h:345
Definition reference_flat_multiset.h:957
reference_flat_multiset(const reference_flat_multiset &other)
Copy constructor.
Definition reference_flat_multiset.h:975
~reference_flat_multiset()
Destructor.
Definition reference_flat_multiset.h:997
reference_flat_multiset()
Constructor.
Definition reference_flat_multiset.h:967
reference_flat_multiset(TIterator first, TIterator last)
Definition reference_flat_multiset.h:988
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
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
ETL_CONSTEXPR TContainer::iterator end(TContainer &container)
Definition iterator.h:997
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