[llvm-branch-commits] [libcxx] 1f7ff62 - [libc++] Fix `std::out_of_range` thrown from `basic_stringbuf::str() &&`
Tobias Hieta via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Thu Aug 3 00:03:15 PDT 2023
Author: Piotr Fusik
Date: 2023-08-03T09:01:33+02:00
New Revision: 1f7ff62d055c8c848fb27aaa2595ae544fce2e69
URL: https://github.com/llvm/llvm-project/commit/1f7ff62d055c8c848fb27aaa2595ae544fce2e69
DIFF: https://github.com/llvm/llvm-project/commit/1f7ff62d055c8c848fb27aaa2595ae544fce2e69.diff
LOG: [libc++] Fix `std::out_of_range` thrown from `basic_stringbuf::str() &&`
Reviewed By: #libc, Mordante, philnik
Differential Revision: https://reviews.llvm.org/D156783
(cherry picked from commit f418cb1a9367d85c7c9b1aa93dc3fa60c8ef9849)
Added:
Modified:
libcxx/include/sstream
libcxx/test/std/input.output/string.streams/istringstream/istringstream.members/str.move.pass.cpp
libcxx/test/std/input.output/string.streams/ostringstream/ostringstream.members/str.move.pass.cpp
libcxx/test/std/input.output/string.streams/stringbuf/stringbuf.members/str.move.pass.cpp
libcxx/test/std/input.output/string.streams/stringstream/stringstream.members/str.move.pass.cpp
Removed:
################################################################################
diff --git a/libcxx/include/sstream b/libcxx/include/sstream
index d7ad0213eb3499..81255c878f7f3a 100644
--- a/libcxx/include/sstream
+++ b/libcxx/include/sstream
@@ -399,8 +399,12 @@ public:
_LIBCPP_HIDE_FROM_ABI_SSTREAM string_type str() const & { return str(__str_.get_allocator()); }
_LIBCPP_HIDE_FROM_ABI_SSTREAM string_type str() && {
+ string_type __result;
const basic_string_view<_CharT, _Traits> __view = view();
- string_type __result(std::move(__str_), __view.data() - __str_.data(), __view.size());
+ if (!__view.empty()) {
+ auto __pos = __view.data() - __str_.data();
+ __result.assign(std::move(__str_), __pos, __view.size());
+ }
__str_.clear();
__init_buf_ptrs();
return __result;
diff --git a/libcxx/test/std/input.output/string.streams/istringstream/istringstream.members/str.move.pass.cpp b/libcxx/test/std/input.output/string.streams/istringstream/istringstream.members/str.move.pass.cpp
index 7c8cf2c713db70..546f82166aaefa 100644
--- a/libcxx/test/std/input.output/string.streams/istringstream/istringstream.members/str.move.pass.cpp
+++ b/libcxx/test/std/input.output/string.streams/istringstream/istringstream.members/str.move.pass.cpp
@@ -31,6 +31,12 @@ static void test() {
assert(s == STR("testing"));
assert(ss.view().empty());
}
+ {
+ std::basic_istringstream<CharT> ss;
+ std::basic_string<CharT> s = std::move(ss).str();
+ assert(s.empty());
+ assert(ss.view().empty());
+ }
}
int main(int, char**) {
diff --git a/libcxx/test/std/input.output/string.streams/ostringstream/ostringstream.members/str.move.pass.cpp b/libcxx/test/std/input.output/string.streams/ostringstream/ostringstream.members/str.move.pass.cpp
index 5fbdf81f0c08ec..57f2384bae52c6 100644
--- a/libcxx/test/std/input.output/string.streams/ostringstream/ostringstream.members/str.move.pass.cpp
+++ b/libcxx/test/std/input.output/string.streams/ostringstream/ostringstream.members/str.move.pass.cpp
@@ -31,6 +31,12 @@ static void test() {
assert(s == STR("testing"));
assert(ss.view().empty());
}
+ {
+ std::basic_ostringstream<CharT> ss;
+ std::basic_string<CharT> s = std::move(ss).str();
+ assert(s.empty());
+ assert(ss.view().empty());
+ }
}
int main(int, char**) {
diff --git a/libcxx/test/std/input.output/string.streams/stringbuf/stringbuf.members/str.move.pass.cpp b/libcxx/test/std/input.output/string.streams/stringbuf/stringbuf.members/str.move.pass.cpp
index f0fa330b4b600f..0f0f540a9c2474 100644
--- a/libcxx/test/std/input.output/string.streams/stringbuf/stringbuf.members/str.move.pass.cpp
+++ b/libcxx/test/std/input.output/string.streams/stringbuf/stringbuf.members/str.move.pass.cpp
@@ -31,6 +31,12 @@ static void test() {
assert(s == STR("testing"));
assert(buf.view().empty());
}
+ {
+ std::basic_stringbuf<CharT> buf;
+ std::basic_string<CharT> s = std::move(buf).str();
+ assert(s.empty());
+ assert(buf.view().empty());
+ }
}
int main(int, char**) {
diff --git a/libcxx/test/std/input.output/string.streams/stringstream/stringstream.members/str.move.pass.cpp b/libcxx/test/std/input.output/string.streams/stringstream/stringstream.members/str.move.pass.cpp
index a6b8ec6c37ebaf..35349c9c288ec1 100644
--- a/libcxx/test/std/input.output/string.streams/stringstream/stringstream.members/str.move.pass.cpp
+++ b/libcxx/test/std/input.output/string.streams/stringstream/stringstream.members/str.move.pass.cpp
@@ -31,6 +31,12 @@ static void test() {
assert(s == STR("testing"));
assert(ss.view().empty());
}
+ {
+ std::basic_stringstream<CharT> ss;
+ std::basic_string<CharT> s = std::move(ss).str();
+ assert(s.empty());
+ assert(ss.view().empty());
+ }
}
int main(int, char**) {
More information about the llvm-branch-commits
mailing list