+2018-12-18 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/string_view [__cplusplus > 201703L]
+ (basic_string_view::starts_with(basic_string_view)): Implement
+ proposed resolution of LWG 3040 to avoid redundant length check.
+ (basic_string_view::starts_with(_CharT)): Implement proposed
+ resolution of LWG 3040 to check at most one character.
+ (basic_string_view::ends_with(_CharT)): Likewise.
+
2018-12-17 Jonathan Wakely <jwakely@redhat.com>
PR libstdc++/71044
#if __cplusplus > 201703L
constexpr bool
starts_with(basic_string_view __x) const noexcept
- {
- return this->size() >= __x.size()
- && this->compare(0, __x.size(), __x) == 0;
- }
+ { return this->substr(0, __x.size()) == __x; }
constexpr bool
starts_with(_CharT __x) const noexcept
- { return this->starts_with(basic_string_view(&__x, 1)); }
+ { return !this->empty() && traits_type::eq(this->front(), __x); }
constexpr bool
starts_with(const _CharT* __x) const noexcept
constexpr bool
ends_with(_CharT __x) const noexcept
- { return this->ends_with(basic_string_view(&__x, 1)); }
+ { return !this->empty() && traits_type::eq(this->back(), __x); }
constexpr bool
ends_with(const _CharT* __x) const noexcept