diff --git a/BAN/BAN/StringView.cpp b/BAN/BAN/StringView.cpp index 3998455d06..1aaf070178 100644 --- a/BAN/BAN/StringView.cpp +++ b/BAN/BAN/StringView.cpp @@ -145,6 +145,22 @@ namespace BAN return m_data[0]; } + BAN::Optional StringView::find(char ch) const + { + for (size_type i = 0; i < m_size; i++) + if (m_data[i] == ch) + return i; + return {}; + } + + BAN::Optional StringView::find(bool(*comp)(char)) const + { + for (size_type i = 0; i < m_size; i++) + if (comp(m_data[i])) + return i; + return {}; + } + bool StringView::contains(char ch) const { for (size_type i = 0; i < m_size; i++) diff --git a/BAN/include/BAN/StringView.h b/BAN/include/BAN/StringView.h index d7d275f7dd..d7c6080ab7 100644 --- a/BAN/include/BAN/StringView.h +++ b/BAN/include/BAN/StringView.h @@ -1,8 +1,9 @@ #pragma once -#include #include +#include #include +#include namespace BAN { @@ -35,6 +36,9 @@ namespace BAN char back() const; char front() const; + BAN::Optional find(char) const; + BAN::Optional find(bool(*comp)(char)) const; + bool contains(char) const; size_type count(char) const;