From e38017975c4e8422101c7faef7e68404caba1a70 Mon Sep 17 00:00:00 2001
From: Martin M <66119648+ebmmy@users.noreply.github.com>
Date: Tue, 1 Oct 2024 17:11:06 +0200
Subject: [PATCH 1/2] Use constexpr for basic_string
---
include/etl/basic_string.h | 258 ++++++++++++++++++-------------------
1 file changed, 129 insertions(+), 129 deletions(-)
diff --git a/include/etl/basic_string.h b/include/etl/basic_string.h
index 1371e80a6..2f13b2682 100644
--- a/include/etl/basic_string.h
+++ b/include/etl/basic_string.h
@@ -173,7 +173,7 @@ namespace etl
/// Gets the current size of the string.
///\return The current size of the string.
//*************************************************************************
- size_type size() const
+ ETL_CONSTEXPR20 size_type size() const
{
return current_size;
}
@@ -182,7 +182,7 @@ namespace etl
/// Gets the current size of the string.
///\return The current size of the string.
//*************************************************************************
- size_type length() const
+ ETL_CONSTEXPR20 size_type length() const
{
return current_size;
}
@@ -191,7 +191,7 @@ namespace etl
/// Checks the 'empty' state of the string.
///\return true if empty.
//*************************************************************************
- bool empty() const
+ ETL_CONSTEXPR20 bool empty() const
{
return (current_size == 0);
}
@@ -200,7 +200,7 @@ namespace etl
/// Checks the 'full' state of the string.
///\return true if full.
//*************************************************************************
- bool full() const
+ ETL_CONSTEXPR20 bool full() const
{
return current_size == CAPACITY;
}
@@ -209,7 +209,7 @@ namespace etl
/// Returns the capacity of the string.
///\return The capacity of the string.
//*************************************************************************
- size_type capacity() const
+ ETL_CONSTEXPR20 size_type capacity() const
{
return CAPACITY;
}
@@ -218,7 +218,7 @@ namespace etl
/// Returns the maximum possible size of the string.
///\return The maximum size of the string.
//*************************************************************************
- size_type max_size() const
+ ETL_CONSTEXPR20 size_type max_size() const
{
return CAPACITY;
}
@@ -227,7 +227,7 @@ namespace etl
/// Returns the remaining capacity.
///\return The remaining capacity.
//*************************************************************************
- size_type available() const
+ ETL_CONSTEXPR20 size_type available() const
{
return max_size() - size();
}
@@ -248,7 +248,7 @@ namespace etl
/// Returns whether the string was truncated by the last operation.
///\return Whether the string was truncated by the last operation.
//*************************************************************************
- bool is_truncated() const
+ ETL_CONSTEXPR bool is_truncated() const
{
return flags.test();
}
@@ -256,7 +256,7 @@ namespace etl
//*************************************************************************
/// Clears the 'truncated' flag.
//*************************************************************************
- void clear_truncated()
+ ETL_CONSTEXPR14 void clear_truncated()
{
flags.set();
}
@@ -266,7 +266,7 @@ namespace etl
//*************************************************************************
/// Sets the 'secure' flag to the requested state.
//*************************************************************************
- void set_secure()
+ ETL_CONSTEXPR14 void set_secure()
{
flags.set();
}
@@ -274,7 +274,7 @@ namespace etl
//*************************************************************************
/// Gets the 'secure' state flag.
//*************************************************************************
- bool is_secure() const
+ ETL_CONSTEXPR bool is_secure() const
{
return flags.test();
}
@@ -285,7 +285,7 @@ namespace etl
//*************************************************************************
/// Constructor.
//*************************************************************************
- string_base(size_type max_size_)
+ ETL_CONSTEXPR20 string_base(size_type max_size_)
: current_size(0)
, CAPACITY(max_size_)
{
@@ -295,7 +295,7 @@ namespace etl
//*************************************************************************
/// Sets the 'truncated' flag.
//*************************************************************************
- void set_truncated(bool status)
+ ETL_CONSTEXPR14 void set_truncated(bool status)
{
flags.set(status);
}
@@ -304,7 +304,7 @@ namespace etl
//*************************************************************************
/// Destructor.
//*************************************************************************
- ~string_base()
+ ETL_CONSTEXPR20 ~string_base()
{
}
@@ -344,7 +344,7 @@ namespace etl
/// Returns an iterator to the beginning of the string.
///\return An iterator to the beginning of the string.
//*********************************************************************
- iterator begin()
+ ETL_CONSTEXPR20 iterator begin()
{
return &p_buffer[0];
}
@@ -353,7 +353,7 @@ namespace etl
/// Returns a const_iterator to the beginning of the string.
///\return A const iterator to the beginning of the string.
//*********************************************************************
- const_iterator begin() const
+ ETL_CONSTEXPR20 const_iterator begin() const
{
return &p_buffer[0];
}
@@ -362,7 +362,7 @@ namespace etl
/// Returns an iterator to the end of the string.
///\return An iterator to the end of the string.
//*********************************************************************
- iterator end()
+ ETL_CONSTEXPR20 iterator end()
{
return &p_buffer[current_size];
}
@@ -371,7 +371,7 @@ namespace etl
/// Returns a const_iterator to the end of the string.
///\return A const iterator to the end of the string.
//*********************************************************************
- const_iterator end() const
+ ETL_CONSTEXPR20 const_iterator end() const
{
return &p_buffer[current_size];
}
@@ -380,7 +380,7 @@ namespace etl
/// Returns a const_iterator to the beginning of the string.
///\return A const iterator to the beginning of the string.
//*********************************************************************
- const_iterator cbegin() const
+ ETL_CONSTEXPR20 const_iterator cbegin() const
{
return &p_buffer[0];
}
@@ -389,7 +389,7 @@ namespace etl
/// Returns a const_iterator to the end of the string.
///\return A const iterator to the end of the string.
//*********************************************************************
- const_iterator cend() const
+ ETL_CONSTEXPR20 const_iterator cend() const
{
return &p_buffer[current_size];
}
@@ -398,7 +398,7 @@ namespace etl
/// Returns an reverse iterator to the reverse beginning of the string.
///\return Iterator to the reverse beginning of the string.
//*********************************************************************
- reverse_iterator rbegin()
+ ETL_CONSTEXPR20 reverse_iterator rbegin()
{
return reverse_iterator(end());
}
@@ -407,7 +407,7 @@ namespace etl
/// Returns a const reverse iterator to the reverse beginning of the string.
///\return Const iterator to the reverse beginning of the string.
//*********************************************************************
- const_reverse_iterator rbegin() const
+ ETL_CONSTEXPR20 const_reverse_iterator rbegin() const
{
return const_reverse_iterator(end());
}
@@ -416,7 +416,7 @@ namespace etl
/// Returns a reverse iterator to the end + 1 of the string.
///\return Reverse iterator to the end + 1 of the string.
//*********************************************************************
- reverse_iterator rend()
+ ETL_CONSTEXPR20 reverse_iterator rend()
{
return reverse_iterator(begin());
}
@@ -425,7 +425,7 @@ namespace etl
/// Returns a const reverse iterator to the end + 1 of the string.
///\return Const reverse iterator to the end + 1 of the string.
//*********************************************************************
- const_reverse_iterator rend() const
+ ETL_CONSTEXPR20 const_reverse_iterator rend() const
{
return const_reverse_iterator(begin());
}
@@ -434,7 +434,7 @@ namespace etl
/// Returns a const reverse iterator to the reverse beginning of the string.
///\return Const reverse iterator to the reverse beginning of the string.
//*********************************************************************
- const_reverse_iterator crbegin() const
+ ETL_CONSTEXPR20 const_reverse_iterator crbegin() const
{
return const_reverse_iterator(cend());
}
@@ -443,7 +443,7 @@ namespace etl
/// Returns a const reverse iterator to the end + 1 of the string.
///\return Const reverse iterator to the end + 1 of the string.
//*********************************************************************
- const_reverse_iterator crend() const
+ ETL_CONSTEXPR20 const_reverse_iterator crend() const
{
return const_reverse_iterator(cbegin());
}
@@ -494,7 +494,7 @@ namespace etl
/// except for a terminator null.
///\param new_size The new size.
//*********************************************************************
- void uninitialized_resize(size_type new_size)
+ ETL_CONSTEXPR14 void uninitialized_resize(size_type new_size)
{
new_size = etl::min(new_size, CAPACITY);
@@ -507,7 +507,7 @@ namespace etl
/// Does not change the string length.
///\param value The character used to fill the string.
//*********************************************************************
- void fill(T value)
+ ETL_CONSTEXPR14 void fill(T value)
{
etl::fill(begin(), end(), value);
}
@@ -517,7 +517,7 @@ namespace etl
///\param i The index.
///\return A reference to the value at index 'i'
//*********************************************************************
- reference operator [](size_type i)
+ ETL_CONSTEXPR20 reference operator [](size_type i)
{
return p_buffer[i];
}
@@ -527,7 +527,7 @@ namespace etl
///\param i The index.
///\return A const reference to the value at index 'i'
//*********************************************************************
- const_reference operator [](size_type i) const
+ ETL_CONSTEXPR20 const_reference operator [](size_type i) const
{
return p_buffer[i];
}
@@ -538,7 +538,7 @@ namespace etl
///\param i The index.
///\return A reference to the value at index 'i'
//*********************************************************************
- reference at(size_type i)
+ ETL_CONSTEXPR20 reference at(size_type i)
{
ETL_ASSERT(i < size(), ETL_ERROR(string_out_of_bounds));
return p_buffer[i];
@@ -550,7 +550,7 @@ namespace etl
///\param i The index.
///\return A const reference to the value at index 'i'
//*********************************************************************
- const_reference at(size_type i) const
+ ETL_CONSTEXPR20 const_reference at(size_type i) const
{
ETL_ASSERT(i < size(), ETL_ERROR(string_out_of_bounds));
return p_buffer[i];
@@ -560,7 +560,7 @@ namespace etl
/// Returns a reference to the first element.
///\return A reference to the first element.
//*********************************************************************
- reference front()
+ ETL_CONSTEXPR20 reference front()
{
return p_buffer[0];
}
@@ -569,7 +569,7 @@ namespace etl
/// Returns a const reference to the first element.
///\return A const reference to the first element.
//*********************************************************************
- const_reference front() const
+ ETL_CONSTEXPR20 const_reference front() const
{
return p_buffer[0];
}
@@ -578,7 +578,7 @@ namespace etl
/// Returns a reference to the last element.
///\return A reference to the last element.
//*********************************************************************
- reference back()
+ ETL_CONSTEXPR20 reference back()
{
return p_buffer[current_size - 1];
}
@@ -587,7 +587,7 @@ namespace etl
/// Returns a const reference to the last element.
///\return A const reference to the last element.
//*********************************************************************
- const_reference back() const
+ ETL_CONSTEXPR20 const_reference back() const
{
return p_buffer[current_size - 1];
}
@@ -596,7 +596,7 @@ namespace etl
/// Returns a pointer to the beginning of the string data.
///\return A pointer to the beginning of the string data.
//*********************************************************************
- pointer data()
+ ETL_CONSTEXPR20 pointer data()
{
return p_buffer;
}
@@ -605,7 +605,7 @@ namespace etl
/// Returns a const pointer to the beginning of the string data.
///\return A const pointer to the beginning of the string data.
//*********************************************************************
- ETL_CONSTEXPR const_pointer data() const
+ ETL_CONSTEXPR20 const_pointer data() const
{
return p_buffer;
}
@@ -614,7 +614,7 @@ namespace etl
/// Returns a pointer to the beginning of the string data.
///\return A pointer to the beginning of the string data.
//*********************************************************************
- pointer data_end()
+ ETL_CONSTEXPR20 pointer data_end()
{
return p_buffer + current_size;
}
@@ -623,7 +623,7 @@ namespace etl
/// Returns a const pointer to the beginning of the string data.
///\return A const pointer to the beginning of the string data.
//*********************************************************************
- const_pointer data_end() const
+ ETL_CONSTEXPR20 const_pointer data_end() const
{
return p_buffer + current_size;
}
@@ -817,7 +817,7 @@ namespace etl
/// Sets 'truncated' if the string is already full.
///\param value The value to add.
//*********************************************************************
- void push_back(T value)
+ ETL_CONSTEXPR20 void push_back(T value)
{
if (current_size != CAPACITY)
{
@@ -840,7 +840,7 @@ namespace etl
/// Removes an element from the end of the string.
/// Does nothing if the string is empty.
//*************************************************************************
- void pop_back()
+ ETL_CONSTEXPR20 void pop_back()
{
if (current_size != 0)
{
@@ -852,7 +852,7 @@ namespace etl
/// Appends to the string.
///\param str The string to append.
//*********************************************************************
- ibasic_string& append(const ibasic_string& str)
+ ETL_CONSTEXPR20 ibasic_string& append(const ibasic_string& str)
{
insert(end(), str.begin(), str.end());
@@ -876,7 +876,7 @@ namespace etl
///\param subposition The position in str.
///\param sublength The number of characters.
//*********************************************************************
- ibasic_string& append(const ibasic_string& str, size_type subposition, size_type sublength = npos)
+ ETL_CONSTEXPR20 ibasic_string& append(const ibasic_string& str, size_type subposition, size_type sublength = npos)
{
ETL_ASSERT(subposition <= str.size(), ETL_ERROR(string_out_of_bounds));
@@ -889,7 +889,7 @@ namespace etl
/// Appends to the string.
///\param str The string to append.
//*********************************************************************
- ibasic_string& append(const T* str)
+ ETL_CONSTEXPR20 ibasic_string& append(const T* str)
{
insert(size(), str);
return *this;
@@ -900,7 +900,7 @@ namespace etl
///\param str The string to append.
///\param n The number of characters.
//*********************************************************************
- ibasic_string& append(const T* str, size_type n)
+ ETL_CONSTEXPR20 ibasic_string& append(const T* str, size_type n)
{
insert(size(), str, n);
return *this;
@@ -911,7 +911,7 @@ namespace etl
///\param n The number of characters.
///\param c The character.
//*********************************************************************
- ibasic_string& append(size_type n, T c)
+ ETL_CONSTEXPR20 ibasic_string& append(size_type n, T c)
{
insert(size(), n, c);
return *this;
@@ -923,7 +923,7 @@ namespace etl
///\param last The last + 1 character to add.
//*********************************************************************
template
- ibasic_string& append(TIterator first, TIterator last)
+ ETL_CONSTEXPR20 ibasic_string& append(TIterator first, TIterator last)
{
insert(end(), first, last);
return *this;
@@ -934,7 +934,7 @@ namespace etl
///\param position The position to insert before.
///\param value The value to insert.
//*********************************************************************
- iterator insert(const_iterator position, T value)
+ ETL_CONSTEXPR20 iterator insert(const_iterator position, T value)
{
// Quick hack, as iterators are pointers.
iterator insert_position = to_iterator(position);
@@ -986,7 +986,7 @@ namespace etl
///\param n The number of elements to add.
///\param value The value to insert.
//*********************************************************************
- iterator insert(const_iterator position, size_type n, T value)
+ ETL_CONSTEXPR20 iterator insert(const_iterator position, size_type n, T value)
{
iterator position_ = to_iterator(position);
@@ -1073,7 +1073,7 @@ namespace etl
///\param last The last + 1 element to add.
//*********************************************************************
template
- iterator insert(const_iterator position, TIterator first, TIterator last)
+ ETL_CONSTEXPR20 iterator insert(const_iterator position, TIterator first, TIterator last)
{
iterator position_ = to_iterator(position);
@@ -1164,7 +1164,7 @@ namespace etl
///\param position The position to insert before.
///\param str The string to insert.
//*********************************************************************
- etl::ibasic_string& insert(size_type position, const etl::ibasic_string& str)
+ ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, const etl::ibasic_string& str)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1222,7 +1222,7 @@ namespace etl
///\param position The position to insert before.
///\param s The string to insert.
//*********************************************************************
- etl::ibasic_string& insert(size_type position, const_pointer s)
+ ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, const_pointer s)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1236,7 +1236,7 @@ namespace etl
///\param s The string to insert.
///\param n The number of characters to insert.
//*********************************************************************
- etl::ibasic_string& insert(size_type position, const_pointer s, size_type n)
+ ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, const_pointer s, size_type n)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1250,7 +1250,7 @@ namespace etl
///\param n The number of characters to insert.
///\param c The character to insert.
//*********************************************************************
- etl::ibasic_string& insert(size_type position, size_type n, value_type c)
+ ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, size_type n, value_type c)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1264,7 +1264,7 @@ namespace etl
///\param length Number of characters.
///\return A reference to this string.
//*********************************************************************
- etl::ibasic_string& erase(size_type position, size_type length_ = npos)
+ ETL_CONSTEXPR20 etl::ibasic_string& erase(size_type position, size_type length_ = npos)
{
// Limit the length.
length_ = etl::min(length_, size() - position);
@@ -1279,7 +1279,7 @@ namespace etl
///\param i_element Iterator to the element.
///\return An iterator pointing to the element that followed the erased element.
//*********************************************************************
- iterator erase(iterator i_element)
+ ETL_CONSTEXPR20 iterator erase(iterator i_element)
{
etl::copy(i_element + 1, end(), i_element);
p_buffer[--current_size] = 0;
@@ -1292,7 +1292,7 @@ namespace etl
///\param i_element Iterator to the element.
///\return An iterator pointing to the element that followed the erased element.
//*********************************************************************
- iterator erase(const_iterator i_element)
+ ETL_CONSTEXPR20 iterator erase(const_iterator i_element)
{
iterator i_element_(to_iterator(i_element));
@@ -1310,7 +1310,7 @@ namespace etl
///\param last Iterator to the last element.
///\return An iterator pointing to the element that followed the erased element.
//*********************************************************************
- iterator erase(const_iterator first, const_iterator last)
+ ETL_CONSTEXPR20 iterator erase(const_iterator first, const_iterator last)
{
iterator first_ = to_iterator(first);
iterator last_ = to_iterator(last);
@@ -1333,7 +1333,7 @@ namespace etl
//*********************************************************************
/// Return a pointer to a C string.
//*********************************************************************
- const_pointer c_str() const
+ ETL_CONSTEXPR20 const_pointer c_str() const
{
return p_buffer;
}
@@ -1344,7 +1344,7 @@ namespace etl
///\param count The number of characters to copy.
///\param pos The position to start copying from.
//*********************************************************************
- size_type copy(pointer dest, size_type count, size_type pos = 0) const
+ ETL_CONSTEXPR20 size_type copy(pointer dest, size_type count, size_type pos = 0) const
{
if (pos < size())
{
@@ -1372,7 +1372,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find(const ibasic_string& str, size_type pos = 0) const
+ ETL_CONSTEXPR20 size_type find(const ibasic_string& str, size_type pos = 0) const
{
if ((pos + str.size()) > size())
{
@@ -1396,7 +1396,7 @@ namespace etl
///\param s Pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find(const_pointer s, size_type pos = 0) const
+ ETL_CONSTEXPR20 size_type find(const_pointer s, size_type pos = 0) const
{
#if ETL_IS_DEBUG_BUILD
if ((pos + etl::strlen(s)) > size())
@@ -1423,7 +1423,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- size_type find(const_pointer s, size_type pos, size_type n) const
+ ETL_CONSTEXPR20 size_type find(const_pointer s, size_type pos, size_type n) const
{
#if ETL_IS_DEBUG_BUILD
if ((pos + etl::strlen(s) - n) > size())
@@ -1449,7 +1449,7 @@ namespace etl
///\param c The character to find.
///\param position The position to start searching from.
//*********************************************************************
- size_type find(T c, size_type position = 0) const
+ ETL_CONSTEXPR20 size_type find(T c, size_type position = 0) const
{
const_iterator i = etl::find(begin() + position, end(), c);
@@ -1468,7 +1468,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type rfind(const ibasic_string& str, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type rfind(const ibasic_string& str, size_type position = npos) const
{
if ((str.size()) > size())
{
@@ -1499,7 +1499,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type rfind(const_pointer s, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type rfind(const_pointer s, size_type position = npos) const
{
size_type len = etl::strlen(s);
@@ -1535,7 +1535,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type rfind(const_pointer s, size_type position, size_type length_) const
+ ETL_CONSTEXPR20 size_type rfind(const_pointer s, size_type position, size_type length_) const
{
if (length_ > size())
{
@@ -1569,7 +1569,7 @@ namespace etl
///\param c The character to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type rfind(T c, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type rfind(T c, size_type position = npos) const
{
if (position >= size())
{
@@ -1596,7 +1596,7 @@ namespace etl
///\param length The number of characters to replace.
///\param str The string to replace it with.
//*********************************************************************
- ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str)
+ ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1618,7 +1618,7 @@ namespace etl
///\param last The one after the position to end at.
///\param str The string to replace it with.
//*********************************************************************
- ibasic_string& replace(const_iterator first, const_iterator last, const ibasic_string& str)
+ ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, const ibasic_string& str)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1647,7 +1647,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with 'str' from 'subposition' of 'sublength'.
//*********************************************************************
- ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength)
+ ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
ETL_ASSERT(subposition <= str.size(), ETL_ERROR(string_out_of_bounds));
@@ -1679,7 +1679,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with pointed to string.
//*********************************************************************
- ibasic_string& replace(size_type position, size_type length_, const_pointer s)
+ ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const_pointer s)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1698,7 +1698,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'first' 'last' with pointed to string.
//*********************************************************************
- ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s)
+ ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1716,7 +1716,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with 'n' characters from pointed to string.
//*********************************************************************
- ibasic_string& replace(size_type position, size_type length_, const_pointer s, size_type n)
+ ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const_pointer s, size_type n)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1735,7 +1735,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'first' to 'last' with 'n' characters from pointed to string.
//*********************************************************************
- ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s, size_type n)
+ ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s, size_type n)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1753,7 +1753,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with 'n' copies of 'c'.
//*********************************************************************
- ibasic_string& replace(size_type position, size_type length_, size_type n, value_type c)
+ ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, size_type n, value_type c)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1772,7 +1772,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'first' of 'last' with 'n' copies of 'c'.
//*********************************************************************
- ibasic_string& replace(const_iterator first, const_iterator last, size_type n, value_type c)
+ ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, size_type n, value_type c)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1791,7 +1791,7 @@ namespace etl
/// Replace characters from 'first' of 'last' with characters from 'first_replace' to 'last_replace'.
//*********************************************************************
template
- ibasic_string& replace(const_iterator first, const_iterator last, TIterator first_replace, TIterator last_replace)
+ ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, TIterator first_replace, TIterator last_replace)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1809,7 +1809,7 @@ namespace etl
//*************************************************************************
/// Compare with string.
//*************************************************************************
- int compare(const ibasic_string& str) const
+ ETL_CONSTEXPR20 int compare(const ibasic_string& str) const
{
return compare(p_buffer,
p_buffer + size(),
@@ -1820,7 +1820,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with string.
//*************************************************************************
- int compare(size_type position, size_type length_, const ibasic_string& str) const
+ ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const ibasic_string& str) const
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1836,7 +1836,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with string / subposition / sublength.
//*************************************************************************
- int compare(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength) const
+ ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength) const
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
ETL_ASSERT(subposition <= str.size(), ETL_ERROR(string_out_of_bounds));
@@ -1854,7 +1854,7 @@ namespace etl
//*************************************************************************
/// Compare with C string
//*************************************************************************
- int compare(const value_type* s) const
+ ETL_CONSTEXPR20 int compare(const value_type* s) const
{
return compare(p_buffer,
p_buffer + size(),
@@ -1865,7 +1865,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with C string.
//*************************************************************************
- int compare(size_type position, size_type length_, const_pointer s) const
+ ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const_pointer s) const
{
return compare(p_buffer + position,
p_buffer + position + length_,
@@ -1876,7 +1876,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with C string / n.
//*************************************************************************
- int compare(size_type position, size_type length_, const_pointer s, size_type n) const
+ ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const_pointer s, size_type n) const
{
return compare(p_buffer + position,
p_buffer + position + length_,
@@ -1889,7 +1889,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_first_of(const ibasic_string& str, size_type position = 0) const
+ ETL_CONSTEXPR20 size_type find_first_of(const ibasic_string& str, size_type position = 0) const
{
return find_first_of(str.c_str(), position, str.size());
}
@@ -1899,7 +1899,7 @@ namespace etl
///\param s Pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_first_of(const_pointer s, size_type position = 0) const
+ ETL_CONSTEXPR20 size_type find_first_of(const_pointer s, size_type position = 0) const
{
return find_first_of(s, position, etl::strlen(s));
}
@@ -1910,7 +1910,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- size_type find_first_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR20 size_type find_first_of(const_pointer s, size_type position, size_type n) const
{
if (position < size())
{
@@ -1934,7 +1934,7 @@ namespace etl
///\param c The character to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_first_of(value_type c, size_type position = 0) const
+ ETL_CONSTEXPR20 size_type find_first_of(value_type c, size_type position = 0) const
{
if (position < size())
{
@@ -1955,7 +1955,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_last_of(const ibasic_string& str, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type find_last_of(const ibasic_string& str, size_type position = npos) const
{
return find_last_of(str.c_str(), position, str.size());
}
@@ -1965,7 +1965,7 @@ namespace etl
///\param s Pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_last_of(const_pointer s, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type find_last_of(const_pointer s, size_type position = npos) const
{
return find_last_of(s, position, etl::strlen(s));
}
@@ -1976,7 +1976,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- size_type find_last_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR20 size_type find_last_of(const_pointer s, size_type position, size_type n) const
{
if (empty())
{
@@ -2009,7 +2009,7 @@ namespace etl
///\param c The character to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_last_of(value_type c, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type find_last_of(value_type c, size_type position = npos) const
{
if (empty())
{
@@ -2039,7 +2039,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_first_not_of(const ibasic_string& str, size_type position = 0) const
+ ETL_CONSTEXPR20 size_type find_first_not_of(const ibasic_string& str, size_type position = 0) const
{
return find_first_not_of(str.c_str(), position, str.size());
}
@@ -2049,7 +2049,7 @@ namespace etl
///\param s Pointer to the content to not find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_first_not_of(const_pointer s, size_type position = 0) const
+ ETL_CONSTEXPR20 size_type find_first_not_of(const_pointer s, size_type position = 0) const
{
return find_first_not_of(s, position, etl::strlen(s));
}
@@ -2060,7 +2060,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- size_type find_first_not_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR20 size_type find_first_not_of(const_pointer s, size_type position, size_type n) const
{
if (position < size())
{
@@ -2091,7 +2091,7 @@ namespace etl
///\param c The character to not find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_first_not_of(value_type c, size_type position = 0) const
+ ETL_CONSTEXPR20 size_type find_first_not_of(value_type c, size_type position = 0) const
{
if (position < size())
{
@@ -2112,7 +2112,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_last_not_of(const ibasic_string& str, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type find_last_not_of(const ibasic_string& str, size_type position = npos) const
{
return find_last_not_of(str.c_str(), position, str.size());
}
@@ -2122,7 +2122,7 @@ namespace etl
///\param s The pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- size_type find_last_not_of(const_pointer s, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type find_last_not_of(const_pointer s, size_type position = npos) const
{
return find_last_not_of(s, position, etl::strlen(s));
}
@@ -2133,7 +2133,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to use.
//*********************************************************************
- size_type find_last_not_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR20 size_type find_last_not_of(const_pointer s, size_type position, size_type n) const
{
if (empty())
{
@@ -2171,7 +2171,7 @@ namespace etl
//*********************************************************************
//
//*********************************************************************
- size_type find_last_not_of(value_type c, size_type position = npos) const
+ ETL_CONSTEXPR20 size_type find_last_not_of(value_type c, size_type position = npos) const
{
if (empty())
{
@@ -2199,7 +2199,7 @@ namespace etl
//*************************************************************************
/// Assignment operator.
//*************************************************************************
- ibasic_string& operator = (const ibasic_string& rhs)
+ ETL_CONSTEXPR20 ibasic_string& operator = (const ibasic_string& rhs)
{
if (&rhs != this)
{
@@ -2212,7 +2212,7 @@ namespace etl
//*************************************************************************
/// Assignment operator.
//*************************************************************************
- ibasic_string& operator = (const_pointer rhs)
+ ETL_CONSTEXPR20 ibasic_string& operator = (const_pointer rhs)
{
assign(rhs);
@@ -2222,7 +2222,7 @@ namespace etl
//*************************************************************************
/// += operator.
//*************************************************************************
- ibasic_string& operator += (const ibasic_string& rhs)
+ ETL_CONSTEXPR20 ibasic_string& operator += (const ibasic_string& rhs)
{
append(rhs);
@@ -2232,7 +2232,7 @@ namespace etl
//*************************************************************************
/// += operator.
//*************************************************************************
- ibasic_string& operator += (const_pointer rhs)
+ ETL_CONSTEXPR20 ibasic_string& operator += (const_pointer rhs)
{
append(rhs);
@@ -2242,7 +2242,7 @@ namespace etl
//*************************************************************************
/// += operator.
//*************************************************************************
- ibasic_string& operator += (T rhs)
+ ETL_CONSTEXPR20 ibasic_string& operator += (T rhs)
{
append(size_type(1), rhs);
@@ -2259,7 +2259,7 @@ namespace etl
//*********************************************************************
/// Clears the free space to string terminator value.
//*********************************************************************
- void initialize_free_space()
+ ETL_CONSTEXPR14 void initialize_free_space()
{
#if ETL_HAS_STRING_TRUNCATION_CHECKS
set_truncated(false);
@@ -2272,7 +2272,7 @@ namespace etl
/// If the last buffer position has a non-null value then the truncated
/// flag will be set.
//*********************************************************************
- void trim_to_terminator()
+ ETL_CONSTEXPR14 void trim_to_terminator()
{
#if ETL_HAS_STRING_TRUNCATION_CHECKS
set_truncated(p_buffer[CAPACITY] != T(0));
@@ -2287,7 +2287,7 @@ namespace etl
//*********************************************************************
/// Constructor.
//*********************************************************************
- ibasic_string(T* p_buffer_, size_type MAX_SIZE_)
+ ETL_CONSTEXPR20 ibasic_string(T* p_buffer_, size_type MAX_SIZE_)
: string_base(MAX_SIZE_),
p_buffer(p_buffer_)
{
@@ -2309,7 +2309,7 @@ namespace etl
//*************************************************************************
/// Fix the internal pointers after a low level memory copy.
//*************************************************************************
- void repair_buffer(T* p_buffer_)
+ ETL_CONSTEXPR14 void repair_buffer(T* p_buffer_)
{
p_buffer = p_buffer_;
}
@@ -2319,7 +2319,7 @@ namespace etl
//*************************************************************************
/// Compare helper function
//*************************************************************************
- int compare(const_pointer first1, const_pointer last1, const_pointer first2, const_pointer last2) const
+ ETL_CONSTEXPR int compare(const_pointer first1, const_pointer last1, const_pointer first2, const_pointer last2) const
{
while ((first1 != last1) && (first2 != last2))
{
@@ -2417,7 +2417,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator ==(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator ==(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return (lhs.size() == rhs.size()) && etl::equal(lhs.begin(), lhs.end(), rhs.begin());
}
@@ -2430,7 +2430,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator ==(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR20 bool operator ==(const etl::ibasic_string& lhs, const T* rhs)
{
return (lhs.size() == etl::strlen(rhs)) && etl::equal(lhs.begin(), lhs.end(), rhs);
}
@@ -2443,7 +2443,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator ==(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator ==(const T* lhs, const etl::ibasic_string& rhs)
{
return (rhs.size() == etl::strlen(lhs)) && etl::equal(rhs.begin(), rhs.end(), lhs);
}
@@ -2456,7 +2456,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator !=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator !=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return !(lhs == rhs);
}
@@ -2469,7 +2469,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator !=(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR20 bool operator !=(const etl::ibasic_string& lhs, const T* rhs)
{
return !(lhs == rhs);
}
@@ -2482,7 +2482,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator !=(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator !=(const T* lhs, const etl::ibasic_string& rhs)
{
return !(lhs == rhs);
}
@@ -2495,7 +2495,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator <(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator <(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return etl::lexicographical_compare(lhs.begin(), lhs.end(), rhs.begin(), rhs.end());
}
@@ -2508,7 +2508,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator <(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR20 bool operator <(const etl::ibasic_string& lhs, const T* rhs)
{
return etl::lexicographical_compare(lhs.begin(), lhs.end(), rhs, rhs + etl::strlen(rhs));
}
@@ -2521,7 +2521,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator <(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator <(const T* lhs, const etl::ibasic_string& rhs)
{
return etl::lexicographical_compare(lhs, lhs + etl::strlen(lhs), rhs.begin(), rhs.end());
}
@@ -2535,7 +2535,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator >(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator >(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return (rhs < lhs);
}
@@ -2548,7 +2548,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator >(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR20 bool operator >(const etl::ibasic_string& lhs, const T* rhs)
{
return (rhs < lhs);
}
@@ -2561,7 +2561,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator >(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator >(const T* lhs, const etl::ibasic_string& rhs)
{
return (rhs < lhs);
}
@@ -2575,7 +2575,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator <=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator <=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return !(lhs > rhs);
}
@@ -2588,7 +2588,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator <=(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR20 bool operator <=(const etl::ibasic_string& lhs, const T* rhs)
{
return !(lhs > rhs);
}
@@ -2601,7 +2601,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator <=(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator <=(const T* lhs, const etl::ibasic_string& rhs)
{
return !(lhs > rhs);
}
@@ -2615,7 +2615,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator >=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator >=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return !(lhs < rhs);
}
@@ -2628,7 +2628,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator >=(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR20 bool operator >=(const etl::ibasic_string& lhs, const T* rhs)
{
return !(lhs < rhs);
}
@@ -2641,7 +2641,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- bool operator >=(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR20 bool operator >=(const T* lhs, const etl::ibasic_string& rhs)
{
return !(lhs < rhs);
}
From b00c75d92d31aefc59029e4062e959e87edf7929 Mon Sep 17 00:00:00 2001
From: Martin M <66119648+ebmmy@users.noreply.github.com>
Date: Wed, 9 Oct 2024 16:10:17 +0200
Subject: [PATCH 2/2] Use ETL_CONSTEXPR14
---
include/etl/basic_string.h | 234 ++++++++++++++++++-------------------
1 file changed, 117 insertions(+), 117 deletions(-)
diff --git a/include/etl/basic_string.h b/include/etl/basic_string.h
index 2f13b2682..f5276de0b 100644
--- a/include/etl/basic_string.h
+++ b/include/etl/basic_string.h
@@ -173,7 +173,7 @@ namespace etl
/// Gets the current size of the string.
///\return The current size of the string.
//*************************************************************************
- ETL_CONSTEXPR20 size_type size() const
+ ETL_CONSTEXPR14 size_type size() const
{
return current_size;
}
@@ -182,7 +182,7 @@ namespace etl
/// Gets the current size of the string.
///\return The current size of the string.
//*************************************************************************
- ETL_CONSTEXPR20 size_type length() const
+ ETL_CONSTEXPR14 size_type length() const
{
return current_size;
}
@@ -191,7 +191,7 @@ namespace etl
/// Checks the 'empty' state of the string.
///\return true if empty.
//*************************************************************************
- ETL_CONSTEXPR20 bool empty() const
+ ETL_CONSTEXPR14 bool empty() const
{
return (current_size == 0);
}
@@ -200,7 +200,7 @@ namespace etl
/// Checks the 'full' state of the string.
///\return true if full.
//*************************************************************************
- ETL_CONSTEXPR20 bool full() const
+ ETL_CONSTEXPR14 bool full() const
{
return current_size == CAPACITY;
}
@@ -209,7 +209,7 @@ namespace etl
/// Returns the capacity of the string.
///\return The capacity of the string.
//*************************************************************************
- ETL_CONSTEXPR20 size_type capacity() const
+ ETL_CONSTEXPR14 size_type capacity() const
{
return CAPACITY;
}
@@ -218,7 +218,7 @@ namespace etl
/// Returns the maximum possible size of the string.
///\return The maximum size of the string.
//*************************************************************************
- ETL_CONSTEXPR20 size_type max_size() const
+ ETL_CONSTEXPR14 size_type max_size() const
{
return CAPACITY;
}
@@ -227,7 +227,7 @@ namespace etl
/// Returns the remaining capacity.
///\return The remaining capacity.
//*************************************************************************
- ETL_CONSTEXPR20 size_type available() const
+ ETL_CONSTEXPR14 size_type available() const
{
return max_size() - size();
}
@@ -285,7 +285,7 @@ namespace etl
//*************************************************************************
/// Constructor.
//*************************************************************************
- ETL_CONSTEXPR20 string_base(size_type max_size_)
+ ETL_CONSTEXPR14 string_base(size_type max_size_)
: current_size(0)
, CAPACITY(max_size_)
{
@@ -344,7 +344,7 @@ namespace etl
/// Returns an iterator to the beginning of the string.
///\return An iterator to the beginning of the string.
//*********************************************************************
- ETL_CONSTEXPR20 iterator begin()
+ ETL_CONSTEXPR14 iterator begin()
{
return &p_buffer[0];
}
@@ -353,7 +353,7 @@ namespace etl
/// Returns a const_iterator to the beginning of the string.
///\return A const iterator to the beginning of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_iterator begin() const
+ ETL_CONSTEXPR14 const_iterator begin() const
{
return &p_buffer[0];
}
@@ -362,7 +362,7 @@ namespace etl
/// Returns an iterator to the end of the string.
///\return An iterator to the end of the string.
//*********************************************************************
- ETL_CONSTEXPR20 iterator end()
+ ETL_CONSTEXPR14 iterator end()
{
return &p_buffer[current_size];
}
@@ -371,7 +371,7 @@ namespace etl
/// Returns a const_iterator to the end of the string.
///\return A const iterator to the end of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_iterator end() const
+ ETL_CONSTEXPR14 const_iterator end() const
{
return &p_buffer[current_size];
}
@@ -380,7 +380,7 @@ namespace etl
/// Returns a const_iterator to the beginning of the string.
///\return A const iterator to the beginning of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_iterator cbegin() const
+ ETL_CONSTEXPR14 const_iterator cbegin() const
{
return &p_buffer[0];
}
@@ -389,7 +389,7 @@ namespace etl
/// Returns a const_iterator to the end of the string.
///\return A const iterator to the end of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_iterator cend() const
+ ETL_CONSTEXPR14 const_iterator cend() const
{
return &p_buffer[current_size];
}
@@ -398,7 +398,7 @@ namespace etl
/// Returns an reverse iterator to the reverse beginning of the string.
///\return Iterator to the reverse beginning of the string.
//*********************************************************************
- ETL_CONSTEXPR20 reverse_iterator rbegin()
+ ETL_CONSTEXPR14 reverse_iterator rbegin()
{
return reverse_iterator(end());
}
@@ -407,7 +407,7 @@ namespace etl
/// Returns a const reverse iterator to the reverse beginning of the string.
///\return Const iterator to the reverse beginning of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_reverse_iterator rbegin() const
+ ETL_CONSTEXPR14 const_reverse_iterator rbegin() const
{
return const_reverse_iterator(end());
}
@@ -416,7 +416,7 @@ namespace etl
/// Returns a reverse iterator to the end + 1 of the string.
///\return Reverse iterator to the end + 1 of the string.
//*********************************************************************
- ETL_CONSTEXPR20 reverse_iterator rend()
+ ETL_CONSTEXPR14 reverse_iterator rend()
{
return reverse_iterator(begin());
}
@@ -425,7 +425,7 @@ namespace etl
/// Returns a const reverse iterator to the end + 1 of the string.
///\return Const reverse iterator to the end + 1 of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_reverse_iterator rend() const
+ ETL_CONSTEXPR14 const_reverse_iterator rend() const
{
return const_reverse_iterator(begin());
}
@@ -434,7 +434,7 @@ namespace etl
/// Returns a const reverse iterator to the reverse beginning of the string.
///\return Const reverse iterator to the reverse beginning of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_reverse_iterator crbegin() const
+ ETL_CONSTEXPR14 const_reverse_iterator crbegin() const
{
return const_reverse_iterator(cend());
}
@@ -443,7 +443,7 @@ namespace etl
/// Returns a const reverse iterator to the end + 1 of the string.
///\return Const reverse iterator to the end + 1 of the string.
//*********************************************************************
- ETL_CONSTEXPR20 const_reverse_iterator crend() const
+ ETL_CONSTEXPR14 const_reverse_iterator crend() const
{
return const_reverse_iterator(cbegin());
}
@@ -517,7 +517,7 @@ namespace etl
///\param i The index.
///\return A reference to the value at index 'i'
//*********************************************************************
- ETL_CONSTEXPR20 reference operator [](size_type i)
+ ETL_CONSTEXPR14 reference operator [](size_type i)
{
return p_buffer[i];
}
@@ -527,7 +527,7 @@ namespace etl
///\param i The index.
///\return A const reference to the value at index 'i'
//*********************************************************************
- ETL_CONSTEXPR20 const_reference operator [](size_type i) const
+ ETL_CONSTEXPR14 const_reference operator [](size_type i) const
{
return p_buffer[i];
}
@@ -538,7 +538,7 @@ namespace etl
///\param i The index.
///\return A reference to the value at index 'i'
//*********************************************************************
- ETL_CONSTEXPR20 reference at(size_type i)
+ ETL_CONSTEXPR14 reference at(size_type i)
{
ETL_ASSERT(i < size(), ETL_ERROR(string_out_of_bounds));
return p_buffer[i];
@@ -550,7 +550,7 @@ namespace etl
///\param i The index.
///\return A const reference to the value at index 'i'
//*********************************************************************
- ETL_CONSTEXPR20 const_reference at(size_type i) const
+ ETL_CONSTEXPR14 const_reference at(size_type i) const
{
ETL_ASSERT(i < size(), ETL_ERROR(string_out_of_bounds));
return p_buffer[i];
@@ -560,7 +560,7 @@ namespace etl
/// Returns a reference to the first element.
///\return A reference to the first element.
//*********************************************************************
- ETL_CONSTEXPR20 reference front()
+ ETL_CONSTEXPR14 reference front()
{
return p_buffer[0];
}
@@ -569,7 +569,7 @@ namespace etl
/// Returns a const reference to the first element.
///\return A const reference to the first element.
//*********************************************************************
- ETL_CONSTEXPR20 const_reference front() const
+ ETL_CONSTEXPR14 const_reference front() const
{
return p_buffer[0];
}
@@ -578,7 +578,7 @@ namespace etl
/// Returns a reference to the last element.
///\return A reference to the last element.
//*********************************************************************
- ETL_CONSTEXPR20 reference back()
+ ETL_CONSTEXPR14 reference back()
{
return p_buffer[current_size - 1];
}
@@ -587,7 +587,7 @@ namespace etl
/// Returns a const reference to the last element.
///\return A const reference to the last element.
//*********************************************************************
- ETL_CONSTEXPR20 const_reference back() const
+ ETL_CONSTEXPR14 const_reference back() const
{
return p_buffer[current_size - 1];
}
@@ -596,7 +596,7 @@ namespace etl
/// Returns a pointer to the beginning of the string data.
///\return A pointer to the beginning of the string data.
//*********************************************************************
- ETL_CONSTEXPR20 pointer data()
+ ETL_CONSTEXPR14 pointer data()
{
return p_buffer;
}
@@ -605,7 +605,7 @@ namespace etl
/// Returns a const pointer to the beginning of the string data.
///\return A const pointer to the beginning of the string data.
//*********************************************************************
- ETL_CONSTEXPR20 const_pointer data() const
+ ETL_CONSTEXPR14 const_pointer data() const
{
return p_buffer;
}
@@ -614,7 +614,7 @@ namespace etl
/// Returns a pointer to the beginning of the string data.
///\return A pointer to the beginning of the string data.
//*********************************************************************
- ETL_CONSTEXPR20 pointer data_end()
+ ETL_CONSTEXPR14 pointer data_end()
{
return p_buffer + current_size;
}
@@ -623,7 +623,7 @@ namespace etl
/// Returns a const pointer to the beginning of the string data.
///\return A const pointer to the beginning of the string data.
//*********************************************************************
- ETL_CONSTEXPR20 const_pointer data_end() const
+ ETL_CONSTEXPR14 const_pointer data_end() const
{
return p_buffer + current_size;
}
@@ -817,7 +817,7 @@ namespace etl
/// Sets 'truncated' if the string is already full.
///\param value The value to add.
//*********************************************************************
- ETL_CONSTEXPR20 void push_back(T value)
+ ETL_CONSTEXPR14 void push_back(T value)
{
if (current_size != CAPACITY)
{
@@ -840,7 +840,7 @@ namespace etl
/// Removes an element from the end of the string.
/// Does nothing if the string is empty.
//*************************************************************************
- ETL_CONSTEXPR20 void pop_back()
+ ETL_CONSTEXPR14 void pop_back()
{
if (current_size != 0)
{
@@ -852,7 +852,7 @@ namespace etl
/// Appends to the string.
///\param str The string to append.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& append(const ibasic_string& str)
+ ETL_CONSTEXPR14 ibasic_string& append(const ibasic_string& str)
{
insert(end(), str.begin(), str.end());
@@ -876,7 +876,7 @@ namespace etl
///\param subposition The position in str.
///\param sublength The number of characters.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& append(const ibasic_string& str, size_type subposition, size_type sublength = npos)
+ ETL_CONSTEXPR14 ibasic_string& append(const ibasic_string& str, size_type subposition, size_type sublength = npos)
{
ETL_ASSERT(subposition <= str.size(), ETL_ERROR(string_out_of_bounds));
@@ -889,7 +889,7 @@ namespace etl
/// Appends to the string.
///\param str The string to append.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& append(const T* str)
+ ETL_CONSTEXPR14 ibasic_string& append(const T* str)
{
insert(size(), str);
return *this;
@@ -900,7 +900,7 @@ namespace etl
///\param str The string to append.
///\param n The number of characters.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& append(const T* str, size_type n)
+ ETL_CONSTEXPR14 ibasic_string& append(const T* str, size_type n)
{
insert(size(), str, n);
return *this;
@@ -911,7 +911,7 @@ namespace etl
///\param n The number of characters.
///\param c The character.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& append(size_type n, T c)
+ ETL_CONSTEXPR14 ibasic_string& append(size_type n, T c)
{
insert(size(), n, c);
return *this;
@@ -923,7 +923,7 @@ namespace etl
///\param last The last + 1 character to add.
//*********************************************************************
template
- ETL_CONSTEXPR20 ibasic_string& append(TIterator first, TIterator last)
+ ETL_CONSTEXPR14 ibasic_string& append(TIterator first, TIterator last)
{
insert(end(), first, last);
return *this;
@@ -934,7 +934,7 @@ namespace etl
///\param position The position to insert before.
///\param value The value to insert.
//*********************************************************************
- ETL_CONSTEXPR20 iterator insert(const_iterator position, T value)
+ ETL_CONSTEXPR14 iterator insert(const_iterator position, T value)
{
// Quick hack, as iterators are pointers.
iterator insert_position = to_iterator(position);
@@ -986,7 +986,7 @@ namespace etl
///\param n The number of elements to add.
///\param value The value to insert.
//*********************************************************************
- ETL_CONSTEXPR20 iterator insert(const_iterator position, size_type n, T value)
+ ETL_CONSTEXPR14 iterator insert(const_iterator position, size_type n, T value)
{
iterator position_ = to_iterator(position);
@@ -1073,7 +1073,7 @@ namespace etl
///\param last The last + 1 element to add.
//*********************************************************************
template
- ETL_CONSTEXPR20 iterator insert(const_iterator position, TIterator first, TIterator last)
+ ETL_CONSTEXPR14 iterator insert(const_iterator position, TIterator first, TIterator last)
{
iterator position_ = to_iterator(position);
@@ -1164,7 +1164,7 @@ namespace etl
///\param position The position to insert before.
///\param str The string to insert.
//*********************************************************************
- ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, const etl::ibasic_string& str)
+ ETL_CONSTEXPR14 etl::ibasic_string& insert(size_type position, const etl::ibasic_string& str)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1222,7 +1222,7 @@ namespace etl
///\param position The position to insert before.
///\param s The string to insert.
//*********************************************************************
- ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, const_pointer s)
+ ETL_CONSTEXPR14 etl::ibasic_string& insert(size_type position, const_pointer s)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1236,7 +1236,7 @@ namespace etl
///\param s The string to insert.
///\param n The number of characters to insert.
//*********************************************************************
- ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, const_pointer s, size_type n)
+ ETL_CONSTEXPR14 etl::ibasic_string& insert(size_type position, const_pointer s, size_type n)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1250,7 +1250,7 @@ namespace etl
///\param n The number of characters to insert.
///\param c The character to insert.
//*********************************************************************
- ETL_CONSTEXPR20 etl::ibasic_string& insert(size_type position, size_type n, value_type c)
+ ETL_CONSTEXPR14 etl::ibasic_string& insert(size_type position, size_type n, value_type c)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1264,7 +1264,7 @@ namespace etl
///\param length Number of characters.
///\return A reference to this string.
//*********************************************************************
- ETL_CONSTEXPR20 etl::ibasic_string& erase(size_type position, size_type length_ = npos)
+ ETL_CONSTEXPR14 etl::ibasic_string& erase(size_type position, size_type length_ = npos)
{
// Limit the length.
length_ = etl::min(length_, size() - position);
@@ -1279,7 +1279,7 @@ namespace etl
///\param i_element Iterator to the element.
///\return An iterator pointing to the element that followed the erased element.
//*********************************************************************
- ETL_CONSTEXPR20 iterator erase(iterator i_element)
+ ETL_CONSTEXPR14 iterator erase(iterator i_element)
{
etl::copy(i_element + 1, end(), i_element);
p_buffer[--current_size] = 0;
@@ -1292,7 +1292,7 @@ namespace etl
///\param i_element Iterator to the element.
///\return An iterator pointing to the element that followed the erased element.
//*********************************************************************
- ETL_CONSTEXPR20 iterator erase(const_iterator i_element)
+ ETL_CONSTEXPR14 iterator erase(const_iterator i_element)
{
iterator i_element_(to_iterator(i_element));
@@ -1310,7 +1310,7 @@ namespace etl
///\param last Iterator to the last element.
///\return An iterator pointing to the element that followed the erased element.
//*********************************************************************
- ETL_CONSTEXPR20 iterator erase(const_iterator first, const_iterator last)
+ ETL_CONSTEXPR14 iterator erase(const_iterator first, const_iterator last)
{
iterator first_ = to_iterator(first);
iterator last_ = to_iterator(last);
@@ -1333,7 +1333,7 @@ namespace etl
//*********************************************************************
/// Return a pointer to a C string.
//*********************************************************************
- ETL_CONSTEXPR20 const_pointer c_str() const
+ ETL_CONSTEXPR14 const_pointer c_str() const
{
return p_buffer;
}
@@ -1344,7 +1344,7 @@ namespace etl
///\param count The number of characters to copy.
///\param pos The position to start copying from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type copy(pointer dest, size_type count, size_type pos = 0) const
+ ETL_CONSTEXPR14 size_type copy(pointer dest, size_type count, size_type pos = 0) const
{
if (pos < size())
{
@@ -1372,7 +1372,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find(const ibasic_string& str, size_type pos = 0) const
+ ETL_CONSTEXPR14 size_type find(const ibasic_string& str, size_type pos = 0) const
{
if ((pos + str.size()) > size())
{
@@ -1396,7 +1396,7 @@ namespace etl
///\param s Pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find(const_pointer s, size_type pos = 0) const
+ ETL_CONSTEXPR14 size_type find(const_pointer s, size_type pos = 0) const
{
#if ETL_IS_DEBUG_BUILD
if ((pos + etl::strlen(s)) > size())
@@ -1423,7 +1423,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find(const_pointer s, size_type pos, size_type n) const
+ ETL_CONSTEXPR14 size_type find(const_pointer s, size_type pos, size_type n) const
{
#if ETL_IS_DEBUG_BUILD
if ((pos + etl::strlen(s) - n) > size())
@@ -1449,7 +1449,7 @@ namespace etl
///\param c The character to find.
///\param position The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find(T c, size_type position = 0) const
+ ETL_CONSTEXPR14 size_type find(T c, size_type position = 0) const
{
const_iterator i = etl::find(begin() + position, end(), c);
@@ -1468,7 +1468,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type rfind(const ibasic_string& str, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type rfind(const ibasic_string& str, size_type position = npos) const
{
if ((str.size()) > size())
{
@@ -1499,7 +1499,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type rfind(const_pointer s, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type rfind(const_pointer s, size_type position = npos) const
{
size_type len = etl::strlen(s);
@@ -1535,7 +1535,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type rfind(const_pointer s, size_type position, size_type length_) const
+ ETL_CONSTEXPR14 size_type rfind(const_pointer s, size_type position, size_type length_) const
{
if (length_ > size())
{
@@ -1569,7 +1569,7 @@ namespace etl
///\param c The character to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type rfind(T c, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type rfind(T c, size_type position = npos) const
{
if (position >= size())
{
@@ -1596,7 +1596,7 @@ namespace etl
///\param length The number of characters to replace.
///\param str The string to replace it with.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str)
+ ETL_CONSTEXPR14 ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1618,7 +1618,7 @@ namespace etl
///\param last The one after the position to end at.
///\param str The string to replace it with.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, const ibasic_string& str)
+ ETL_CONSTEXPR14 ibasic_string& replace(const_iterator first, const_iterator last, const ibasic_string& str)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1647,7 +1647,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with 'str' from 'subposition' of 'sublength'.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength)
+ ETL_CONSTEXPR14 ibasic_string& replace(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
ETL_ASSERT(subposition <= str.size(), ETL_ERROR(string_out_of_bounds));
@@ -1679,7 +1679,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with pointed to string.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const_pointer s)
+ ETL_CONSTEXPR14 ibasic_string& replace(size_type position, size_type length_, const_pointer s)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1698,7 +1698,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'first' 'last' with pointed to string.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s)
+ ETL_CONSTEXPR14 ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1716,7 +1716,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with 'n' characters from pointed to string.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, const_pointer s, size_type n)
+ ETL_CONSTEXPR14 ibasic_string& replace(size_type position, size_type length_, const_pointer s, size_type n)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1735,7 +1735,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'first' to 'last' with 'n' characters from pointed to string.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s, size_type n)
+ ETL_CONSTEXPR14 ibasic_string& replace(const_iterator first, const_iterator last, const_pointer s, size_type n)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1753,7 +1753,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'position' of 'length' with 'n' copies of 'c'.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(size_type position, size_type length_, size_type n, value_type c)
+ ETL_CONSTEXPR14 ibasic_string& replace(size_type position, size_type length_, size_type n, value_type c)
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1772,7 +1772,7 @@ namespace etl
//*********************************************************************
/// Replace characters from 'first' of 'last' with 'n' copies of 'c'.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, size_type n, value_type c)
+ ETL_CONSTEXPR14 ibasic_string& replace(const_iterator first, const_iterator last, size_type n, value_type c)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1791,7 +1791,7 @@ namespace etl
/// Replace characters from 'first' of 'last' with characters from 'first_replace' to 'last_replace'.
//*********************************************************************
template
- ETL_CONSTEXPR20 ibasic_string& replace(const_iterator first, const_iterator last, TIterator first_replace, TIterator last_replace)
+ ETL_CONSTEXPR14 ibasic_string& replace(const_iterator first, const_iterator last, TIterator first_replace, TIterator last_replace)
{
// Quick hack, as iterators are pointers.
iterator first_ = to_iterator(first);
@@ -1809,7 +1809,7 @@ namespace etl
//*************************************************************************
/// Compare with string.
//*************************************************************************
- ETL_CONSTEXPR20 int compare(const ibasic_string& str) const
+ ETL_CONSTEXPR14 int compare(const ibasic_string& str) const
{
return compare(p_buffer,
p_buffer + size(),
@@ -1820,7 +1820,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with string.
//*************************************************************************
- ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const ibasic_string& str) const
+ ETL_CONSTEXPR14 int compare(size_type position, size_type length_, const ibasic_string& str) const
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
@@ -1836,7 +1836,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with string / subposition / sublength.
//*************************************************************************
- ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength) const
+ ETL_CONSTEXPR14 int compare(size_type position, size_type length_, const ibasic_string& str, size_type subposition, size_type sublength) const
{
ETL_ASSERT(position <= size(), ETL_ERROR(string_out_of_bounds));
ETL_ASSERT(subposition <= str.size(), ETL_ERROR(string_out_of_bounds));
@@ -1854,7 +1854,7 @@ namespace etl
//*************************************************************************
/// Compare with C string
//*************************************************************************
- ETL_CONSTEXPR20 int compare(const value_type* s) const
+ ETL_CONSTEXPR14 int compare(const value_type* s) const
{
return compare(p_buffer,
p_buffer + size(),
@@ -1865,7 +1865,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with C string.
//*************************************************************************
- ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const_pointer s) const
+ ETL_CONSTEXPR14 int compare(size_type position, size_type length_, const_pointer s) const
{
return compare(p_buffer + position,
p_buffer + position + length_,
@@ -1876,7 +1876,7 @@ namespace etl
//*************************************************************************
/// Compare position / length with C string / n.
//*************************************************************************
- ETL_CONSTEXPR20 int compare(size_type position, size_type length_, const_pointer s, size_type n) const
+ ETL_CONSTEXPR14 int compare(size_type position, size_type length_, const_pointer s, size_type n) const
{
return compare(p_buffer + position,
p_buffer + position + length_,
@@ -1889,7 +1889,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_of(const ibasic_string& str, size_type position = 0) const
+ ETL_CONSTEXPR14 size_type find_first_of(const ibasic_string& str, size_type position = 0) const
{
return find_first_of(str.c_str(), position, str.size());
}
@@ -1899,7 +1899,7 @@ namespace etl
///\param s Pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_of(const_pointer s, size_type position = 0) const
+ ETL_CONSTEXPR14 size_type find_first_of(const_pointer s, size_type position = 0) const
{
return find_first_of(s, position, etl::strlen(s));
}
@@ -1910,7 +1910,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR14 size_type find_first_of(const_pointer s, size_type position, size_type n) const
{
if (position < size())
{
@@ -1934,7 +1934,7 @@ namespace etl
///\param c The character to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_of(value_type c, size_type position = 0) const
+ ETL_CONSTEXPR14 size_type find_first_of(value_type c, size_type position = 0) const
{
if (position < size())
{
@@ -1955,7 +1955,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_of(const ibasic_string& str, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type find_last_of(const ibasic_string& str, size_type position = npos) const
{
return find_last_of(str.c_str(), position, str.size());
}
@@ -1965,7 +1965,7 @@ namespace etl
///\param s Pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_of(const_pointer s, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type find_last_of(const_pointer s, size_type position = npos) const
{
return find_last_of(s, position, etl::strlen(s));
}
@@ -1976,7 +1976,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR14 size_type find_last_of(const_pointer s, size_type position, size_type n) const
{
if (empty())
{
@@ -2009,7 +2009,7 @@ namespace etl
///\param c The character to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_of(value_type c, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type find_last_of(value_type c, size_type position = npos) const
{
if (empty())
{
@@ -2039,7 +2039,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_not_of(const ibasic_string& str, size_type position = 0) const
+ ETL_CONSTEXPR14 size_type find_first_not_of(const ibasic_string& str, size_type position = 0) const
{
return find_first_not_of(str.c_str(), position, str.size());
}
@@ -2049,7 +2049,7 @@ namespace etl
///\param s Pointer to the content to not find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_not_of(const_pointer s, size_type position = 0) const
+ ETL_CONSTEXPR14 size_type find_first_not_of(const_pointer s, size_type position = 0) const
{
return find_first_not_of(s, position, etl::strlen(s));
}
@@ -2060,7 +2060,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to search for.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_not_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR14 size_type find_first_not_of(const_pointer s, size_type position, size_type n) const
{
if (position < size())
{
@@ -2091,7 +2091,7 @@ namespace etl
///\param c The character to not find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_first_not_of(value_type c, size_type position = 0) const
+ ETL_CONSTEXPR14 size_type find_first_not_of(value_type c, size_type position = 0) const
{
if (position < size())
{
@@ -2112,7 +2112,7 @@ namespace etl
///\param str The content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_not_of(const ibasic_string& str, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type find_last_not_of(const ibasic_string& str, size_type position = npos) const
{
return find_last_not_of(str.c_str(), position, str.size());
}
@@ -2122,7 +2122,7 @@ namespace etl
///\param s The pointer to the content to find
///\param pos The position to start searching from.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_not_of(const_pointer s, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type find_last_not_of(const_pointer s, size_type position = npos) const
{
return find_last_not_of(s, position, etl::strlen(s));
}
@@ -2133,7 +2133,7 @@ namespace etl
///\param pos The position to start searching from.
///\param n The number of characters to use.
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_not_of(const_pointer s, size_type position, size_type n) const
+ ETL_CONSTEXPR14 size_type find_last_not_of(const_pointer s, size_type position, size_type n) const
{
if (empty())
{
@@ -2171,7 +2171,7 @@ namespace etl
//*********************************************************************
//
//*********************************************************************
- ETL_CONSTEXPR20 size_type find_last_not_of(value_type c, size_type position = npos) const
+ ETL_CONSTEXPR14 size_type find_last_not_of(value_type c, size_type position = npos) const
{
if (empty())
{
@@ -2199,7 +2199,7 @@ namespace etl
//*************************************************************************
/// Assignment operator.
//*************************************************************************
- ETL_CONSTEXPR20 ibasic_string& operator = (const ibasic_string& rhs)
+ ETL_CONSTEXPR14 ibasic_string& operator = (const ibasic_string& rhs)
{
if (&rhs != this)
{
@@ -2212,7 +2212,7 @@ namespace etl
//*************************************************************************
/// Assignment operator.
//*************************************************************************
- ETL_CONSTEXPR20 ibasic_string& operator = (const_pointer rhs)
+ ETL_CONSTEXPR14 ibasic_string& operator = (const_pointer rhs)
{
assign(rhs);
@@ -2222,7 +2222,7 @@ namespace etl
//*************************************************************************
/// += operator.
//*************************************************************************
- ETL_CONSTEXPR20 ibasic_string& operator += (const ibasic_string& rhs)
+ ETL_CONSTEXPR14 ibasic_string& operator += (const ibasic_string& rhs)
{
append(rhs);
@@ -2232,7 +2232,7 @@ namespace etl
//*************************************************************************
/// += operator.
//*************************************************************************
- ETL_CONSTEXPR20 ibasic_string& operator += (const_pointer rhs)
+ ETL_CONSTEXPR14 ibasic_string& operator += (const_pointer rhs)
{
append(rhs);
@@ -2242,7 +2242,7 @@ namespace etl
//*************************************************************************
/// += operator.
//*************************************************************************
- ETL_CONSTEXPR20 ibasic_string& operator += (T rhs)
+ ETL_CONSTEXPR14 ibasic_string& operator += (T rhs)
{
append(size_type(1), rhs);
@@ -2287,7 +2287,7 @@ namespace etl
//*********************************************************************
/// Constructor.
//*********************************************************************
- ETL_CONSTEXPR20 ibasic_string(T* p_buffer_, size_type MAX_SIZE_)
+ ETL_CONSTEXPR14 ibasic_string(T* p_buffer_, size_type MAX_SIZE_)
: string_base(MAX_SIZE_),
p_buffer(p_buffer_)
{
@@ -2417,7 +2417,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator ==(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator ==(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return (lhs.size() == rhs.size()) && etl::equal(lhs.begin(), lhs.end(), rhs.begin());
}
@@ -2430,7 +2430,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator ==(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR14 bool operator ==(const etl::ibasic_string& lhs, const T* rhs)
{
return (lhs.size() == etl::strlen(rhs)) && etl::equal(lhs.begin(), lhs.end(), rhs);
}
@@ -2443,7 +2443,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator ==(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator ==(const T* lhs, const etl::ibasic_string& rhs)
{
return (rhs.size() == etl::strlen(lhs)) && etl::equal(rhs.begin(), rhs.end(), lhs);
}
@@ -2456,7 +2456,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator !=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator !=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return !(lhs == rhs);
}
@@ -2469,7 +2469,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator !=(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR14 bool operator !=(const etl::ibasic_string& lhs, const T* rhs)
{
return !(lhs == rhs);
}
@@ -2482,7 +2482,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator !=(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator !=(const T* lhs, const etl::ibasic_string& rhs)
{
return !(lhs == rhs);
}
@@ -2495,7 +2495,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator <(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator <(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return etl::lexicographical_compare(lhs.begin(), lhs.end(), rhs.begin(), rhs.end());
}
@@ -2508,7 +2508,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator <(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR14 bool operator <(const etl::ibasic_string& lhs, const T* rhs)
{
return etl::lexicographical_compare(lhs.begin(), lhs.end(), rhs, rhs + etl::strlen(rhs));
}
@@ -2521,7 +2521,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator <(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator <(const T* lhs, const etl::ibasic_string& rhs)
{
return etl::lexicographical_compare(lhs, lhs + etl::strlen(lhs), rhs.begin(), rhs.end());
}
@@ -2535,7 +2535,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator >(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator >(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return (rhs < lhs);
}
@@ -2548,7 +2548,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator >(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR14 bool operator >(const etl::ibasic_string& lhs, const T* rhs)
{
return (rhs < lhs);
}
@@ -2561,7 +2561,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator >(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator >(const T* lhs, const etl::ibasic_string& rhs)
{
return (rhs < lhs);
}
@@ -2575,7 +2575,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator <=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator <=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return !(lhs > rhs);
}
@@ -2588,7 +2588,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator <=(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR14 bool operator <=(const etl::ibasic_string& lhs, const T* rhs)
{
return !(lhs > rhs);
}
@@ -2601,7 +2601,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator <=(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator <=(const T* lhs, const etl::ibasic_string& rhs)
{
return !(lhs > rhs);
}
@@ -2615,7 +2615,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator >=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator >=(const etl::ibasic_string& lhs, const etl::ibasic_string& rhs)
{
return !(lhs < rhs);
}
@@ -2628,7 +2628,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator >=(const etl::ibasic_string& lhs, const T* rhs)
+ ETL_CONSTEXPR14 bool operator >=(const etl::ibasic_string& lhs, const T* rhs)
{
return !(lhs < rhs);
}
@@ -2641,7 +2641,7 @@ namespace etl
///\ingroup string
//***************************************************************************
template
- ETL_CONSTEXPR20 bool operator >=(const T* lhs, const etl::ibasic_string& rhs)
+ ETL_CONSTEXPR14 bool operator >=(const T* lhs, const etl::ibasic_string& rhs)
{
return !(lhs < rhs);
}