diff --git a/libcxx/include/string b/libcxx/include/string --- a/libcxx/include/string +++ b/libcxx/include/string @@ -1455,6 +1455,8 @@ #endif // _LIBCPP_DEBUG_LEVEL == 2 private: + _LIBCPP_HIDE_FROM_ABI static bool __use_sso(size_type __sz) { return __sz < __min_cap; } + _LIBCPP_INLINE_VISIBILITY allocator_type& __alloc() _NOEXCEPT {return __r_.second();} @@ -1859,7 +1861,7 @@ if (__reserve > max_size()) this->__throw_length_error(); pointer __p; - if (__reserve < __min_cap) + if (__use_sso(__reserve)) { __set_short_size(__sz); __p = __get_short_pointer(); @@ -1883,7 +1885,7 @@ if (__sz > max_size()) this->__throw_length_error(); pointer __p; - if (__sz < __min_cap) + if (__use_sso(__sz)) { __set_short_size(__sz); __p = __get_short_pointer(); @@ -1975,7 +1977,7 @@ void basic_string<_CharT, _Traits, _Allocator>::__init_copy_ctor_external( const value_type* __s, size_type __sz) { pointer __p; - if (__sz < __min_cap) { + if (__use_sso(__sz)) { __p = __get_short_pointer(); __set_short_size(__sz); } else { @@ -2042,7 +2044,7 @@ if (__n > max_size()) this->__throw_length_error(); pointer __p; - if (__n < __min_cap) + if (__use_sso(__n)) { __set_short_size(__n); __p = __get_short_pointer(); @@ -2194,7 +2196,7 @@ if (__sz > max_size()) this->__throw_length_error(); pointer __p; - if (__sz < __min_cap) + if (__use_sso(__sz)) { __set_short_size(__sz); __p = __get_short_pointer(); @@ -2398,7 +2400,7 @@ basic_string<_CharT, _Traits, _Allocator>::assign(const value_type* __s, size_type __n) { _LIBCPP_ASSERT(__n == 0 || __s != nullptr, "string::assign received nullptr"); - return (__builtin_constant_p(__n) && __n < __min_cap) + return (__builtin_constant_p(__n) && __use_sso(__n)) ? __assign_short(__s, __n) : __assign_external(__s, __n); } @@ -2601,7 +2603,7 @@ { _LIBCPP_ASSERT(__s != nullptr, "string::assign received nullptr"); return __builtin_constant_p(*__s) - ? (traits_type::length(__s) < __min_cap + ? (__use_sso(traits_type::length(__s)) ? __assign_short(__s, traits_type::length(__s)) : __assign_external(__s, traits_type::length(__s))) : __assign_external(__s);