forked from OSchip/llvm-project
Replaced checking in string_view::remove_suffix/remove_prefix by _LIBCPP_ASSERT, since this is technically undefined behavior. Fixes PR#21496
llvm-svn: 221717
This commit is contained in:
parent
e396bfc064
commit
eb63c5e28c
|
@ -313,8 +313,7 @@ _LIBCPP_BEGIN_NAMESPACE_LFTS
|
|||
_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY
|
||||
void remove_prefix(size_type __n) _NOEXCEPT
|
||||
{
|
||||
if (__n > __size)
|
||||
__n = __size;
|
||||
_LIBCPP_ASSERT(n <= size(), "remove_prefix() can't remove more than size()");
|
||||
__data += __n;
|
||||
__size -= __n;
|
||||
}
|
||||
|
@ -322,8 +321,7 @@ _LIBCPP_BEGIN_NAMESPACE_LFTS
|
|||
_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY
|
||||
void remove_suffix(size_type __n) _NOEXCEPT
|
||||
{
|
||||
if (__n > __size)
|
||||
__n = __size;
|
||||
_LIBCPP_ASSERT(n <= size(), "remove_suffix() can't remove more than size()");
|
||||
__size -= __n;
|
||||
}
|
||||
|
||||
|
|
|
@ -28,13 +28,11 @@ void test ( const CharT *s, size_t len ) {
|
|||
sv1.remove_prefix ( 1 );
|
||||
assert ( sv1.size() == (len - 1));
|
||||
assert ( sv1.data() == (s + 1));
|
||||
sv1.remove_prefix ( len - 1 );
|
||||
}
|
||||
|
||||
sv1.remove_prefix ( len - 1 );
|
||||
assert ( sv1.size() == 0 );
|
||||
|
||||
SV sv2 ( s );
|
||||
sv2.remove_prefix ( len << 1 );
|
||||
sv1.remove_prefix ( 0 );
|
||||
assert ( sv1.size() == 0 );
|
||||
}
|
||||
}
|
||||
|
@ -72,7 +70,6 @@ int main () {
|
|||
static_assert ( test_ce ( 5, 0 ) == 5, "" );
|
||||
static_assert ( test_ce ( 5, 1 ) == 4, "" );
|
||||
static_assert ( test_ce ( 5, 5 ) == 0, "" );
|
||||
static_assert ( test_ce ( 5, 9 ) == 0, "" );
|
||||
static_assert ( test_ce ( 9, 3 ) == 6, "" );
|
||||
}
|
||||
#endif
|
||||
|
|
|
@ -27,13 +27,11 @@ void test ( const CharT *s, size_t len ) {
|
|||
sv1.remove_suffix ( 1 );
|
||||
assert ( sv1.size() == (len - 1));
|
||||
assert ( sv1.data() == s);
|
||||
sv1.remove_suffix ( len - 1 );
|
||||
}
|
||||
|
||||
sv1.remove_suffix ( len - 1 );
|
||||
assert ( sv1.size() == 0 );
|
||||
|
||||
SV sv2 ( s );
|
||||
sv2.remove_suffix ( len << 1 );
|
||||
sv1.remove_suffix ( 0 );
|
||||
assert ( sv1.size() == 0 );
|
||||
}
|
||||
|
||||
|
@ -72,7 +70,6 @@ int main () {
|
|||
static_assert ( test_ce ( 5, 0 ) == 5, "" );
|
||||
static_assert ( test_ce ( 5, 1 ) == 4, "" );
|
||||
static_assert ( test_ce ( 5, 5 ) == 0, "" );
|
||||
static_assert ( test_ce ( 5, 9 ) == 0, "" );
|
||||
static_assert ( test_ce ( 9, 3 ) == 6, "" );
|
||||
}
|
||||
#endif
|
||||
|
|
Loading…
Reference in New Issue