[ox/std] Fix BString assign and compare

This commit is contained in:
Gary Talent 2023-02-11 02:32:24 -06:00
parent 08899074cf
commit 9561a68483

View File

@ -111,7 +111,7 @@ constexpr BString<size> &BString<size>::operator=(const char *str) noexcept {
} }
ox_memcpy(m_buff, str, strLen); ox_memcpy(m_buff, str, strLen);
// make sure last element is a null terminator // make sure last element is a null terminator
m_buff[cap() - 1] = 0; m_buff[cap()] = 0;
return *this; return *this;
} }
@ -168,16 +168,7 @@ constexpr BString<size> BString<size>::operator+(Integer_c auto i) const noexcep
template<std::size_t buffLen> template<std::size_t buffLen>
constexpr bool BString<buffLen>::operator==(const BString<buffLen> &other) const noexcept { constexpr bool BString<buffLen>::operator==(const BString<buffLen> &other) const noexcept {
bool retval = true; return ox::StringView(*this) == ox::StringView(other);
std::size_t i = 0;
while (i < buffLen && (m_buff[i] || other.m_buff[i])) {
if (m_buff[i] != other.m_buff[i]) {
retval = false;
break;
}
i++;
}
return retval;
} }
template<std::size_t buffLen> template<std::size_t buffLen>