diff --git a/libcxx/test/libcxx/strings/basic.string/string.access/assert.back.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.access/assert.back.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.access/assert.back.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.access/assert.back.pass.cpp @@ -20,17 +20,15 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + S s; + TEST_LIBCPP_ASSERT_FAILURE(s.back(), "string::back(): string is empty"); +} + int main(int, char**) { - { - std::string s; - TEST_LIBCPP_ASSERT_FAILURE(s.back(), "string::back(): string is empty"); - } - - { - typedef std::basic_string, min_allocator > S; - S s; - TEST_LIBCPP_ASSERT_FAILURE(s.back(), "string::back(): string is empty"); - } - - return 0; + test(); + test, min_allocator > >(); + + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.access/assert.cback.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.access/assert.cback.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.access/assert.cback.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.access/assert.cback.pass.cpp @@ -20,17 +20,15 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + const S s; + TEST_LIBCPP_ASSERT_FAILURE(s.back(), "string::back(): string is empty"); +} + int main(int, char**) { - { - std::string const s; - TEST_LIBCPP_ASSERT_FAILURE(s.back(), "string::back(): string is empty"); - } - - { - typedef std::basic_string, min_allocator > S; - const S s; - TEST_LIBCPP_ASSERT_FAILURE(s.back(), "string::back(): string is empty"); - } - - return 0; + test(); + test, min_allocator > >(); + + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.access/assert.cfront.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.access/assert.cfront.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.access/assert.cfront.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.access/assert.cfront.pass.cpp @@ -20,18 +20,15 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + const S s; + TEST_LIBCPP_ASSERT_FAILURE(s.front(), "string::front(): string is empty"); +} + int main(int, char**) { - { - typedef std::string S; - const S s; - TEST_LIBCPP_ASSERT_FAILURE(s.front(), "string::front(): string is empty"); - } - - { - typedef std::basic_string, min_allocator > S; - const S s; - TEST_LIBCPP_ASSERT_FAILURE(s.front(), "string::front(): string is empty"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.access/assert.cindex.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.access/assert.cindex.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.access/assert.cindex.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.access/assert.cindex.pass.cpp @@ -21,20 +21,16 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + const S s; + assert(s[0] == 0); + TEST_LIBCPP_ASSERT_FAILURE(s[1], "string index out of bounds"); +} + int main(int, char**) { - { - typedef std::basic_string, min_allocator > S; - const S s; - assert(s[0] == 0); - TEST_LIBCPP_ASSERT_FAILURE(s[1], "string index out of bounds"); - } - - { - typedef std::string S; - const S s; - assert(s[0] == 0); - TEST_LIBCPP_ASSERT_FAILURE(s[1], "string index out of bounds"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.access/assert.front.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.access/assert.front.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.access/assert.front.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.access/assert.front.pass.cpp @@ -21,18 +21,15 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + S s; + TEST_LIBCPP_ASSERT_FAILURE(s.front(), "string::front(): string is empty"); +} + int main(int, char**) { - { - typedef std::string S; - S s; - TEST_LIBCPP_ASSERT_FAILURE(s.front(), "string::front(): string is empty"); - } - - { - typedef std::basic_string, min_allocator > S; - S s; - TEST_LIBCPP_ASSERT_FAILURE(s.front(), "string::front(): string is empty"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.access/assert.index.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.access/assert.index.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.access/assert.index.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.access/assert.index.pass.cpp @@ -21,20 +21,16 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + S s; + assert(s[0] == 0); + TEST_LIBCPP_ASSERT_FAILURE(s[1], "string index out of bounds"); +} + int main(int, char**) { - { - typedef std::string S; - S s; - assert(s[0] == 0); - TEST_LIBCPP_ASSERT_FAILURE(s[1], "string index out of bounds"); - } - - { - typedef std::basic_string, min_allocator > S; - S s; - assert(s[0] == 0); - TEST_LIBCPP_ASSERT_FAILURE(s[1], "string index out of bounds"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.add.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.add.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.add.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.add.pass.cpp @@ -19,26 +19,19 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + C c(1, '\0'); + typename C::iterator i = c.begin(); + i += 1; + assert(i == c.end()); + i = c.begin(); + TEST_LIBCPP_ASSERT_FAILURE(i += 2, "Attempted to add/subtract an iterator outside its valid range"); +} + int main(int, char**) { - { - typedef std::string C; - C c(1, '\0'); - C::iterator i = c.begin(); - i += 1; - assert(i == c.end()); - i = c.begin(); - TEST_LIBCPP_ASSERT_FAILURE(i += 2, "Attempted to add/subtract an iterator outside its valid range"); - } - - { - typedef std::basic_string, min_allocator > C; - C c(1, '\0'); - C::iterator i = c.begin(); - i += 1; - assert(i == c.end()); - i = c.begin(); - TEST_LIBCPP_ASSERT_FAILURE(i += 2, "Attempted to add/subtract an iterator outside its valid range"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.compare.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.compare.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.compare.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.compare.pass.cpp @@ -18,20 +18,16 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + S s1; + S s2; + TEST_LIBCPP_ASSERT_FAILURE(s1.begin() < s2.begin(), "Attempted to compare incomparable iterators"); +} + int main(int, char**) { - { - typedef std::string S; - S s1; - S s2; - TEST_LIBCPP_ASSERT_FAILURE(s1.begin() < s2.begin(), "Attempted to compare incomparable iterators"); - } - - { - typedef std::basic_string, min_allocator > S; - S s1; - S s2; - TEST_LIBCPP_ASSERT_FAILURE(s1.begin() < s2.begin(), "Attempted to compare incomparable iterators"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.decrement.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.decrement.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.decrement.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.decrement.pass.cpp @@ -19,24 +19,18 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + C c(1, '\0'); + typename C::iterator i = c.end(); + --i; + assert(i == c.begin()); + TEST_LIBCPP_ASSERT_FAILURE(--i, "Attempted to decrement a non-decrementable iterator"); +} + int main(int, char**) { - { - typedef std::string C; - C c(1, '\0'); - C::iterator i = c.end(); - --i; - assert(i == c.begin()); - TEST_LIBCPP_ASSERT_FAILURE(--i, "Attempted to decrement a non-decrementable iterator"); - } - - { - typedef std::basic_string, min_allocator > C; - C c(1, '\0'); - C::iterator i = c.end(); - --i; - assert(i == c.begin()); - TEST_LIBCPP_ASSERT_FAILURE(--i, "Attempted to decrement a non-decrementable iterator"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.dereference.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.dereference.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.dereference.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.dereference.pass.cpp @@ -18,20 +18,16 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + C c(1, '\0'); + typename C::iterator i = c.end(); + TEST_LIBCPP_ASSERT_FAILURE(*i, "Attempted to dereference a non-dereferenceable iterator"); +} + int main(int, char**) { - { - typedef std::string C; - C c(1, '\0'); - C::iterator i = c.end(); - TEST_LIBCPP_ASSERT_FAILURE(*i, "Attempted to dereference a non-dereferenceable iterator"); - } - - { - typedef std::basic_string, min_allocator > C; - C c(1, '\0'); - C::iterator i = c.end(); - TEST_LIBCPP_ASSERT_FAILURE(*i, "Attempted to dereference a non-dereferenceable iterator"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.increment.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.increment.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.increment.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.increment.pass.cpp @@ -19,24 +19,18 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + C c(1, '\0'); + typename C::iterator i = c.begin(); + ++i; + assert(i == c.end()); + TEST_LIBCPP_ASSERT_FAILURE(++i, "Attempted to increment a non-incrementable iterator"); +} + int main(int, char**) { - { - typedef std::string C; - C c(1, '\0'); - C::iterator i = c.begin(); - ++i; - assert(i == c.end()); - TEST_LIBCPP_ASSERT_FAILURE(++i, "Attempted to increment a non-incrementable iterator"); - } - - { - typedef std::basic_string, min_allocator > C; - C c(1, '\0'); - C::iterator i = c.begin(); - ++i; - assert(i == c.end()); - TEST_LIBCPP_ASSERT_FAILURE(++i, "Attempted to increment a non-incrementable iterator"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.index.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.index.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.index.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.index.pass.cpp @@ -19,23 +19,18 @@ #include "check_assertion.h" #include "min_allocator.h" -int main(int, char**) { +template +void test() { using T = decltype(std::uint8_t() - std::uint8_t()); - { - typedef std::string C; - C c(1, '\0'); - C::iterator i = c.begin(); - assert(i[0] == 0); - TEST_LIBCPP_ASSERT_FAILURE(i[1], "Attempted to subscript an iterator outside its valid range"); - } - - { - typedef std::basic_string, min_allocator > C; - C c(1, '\0'); - C::iterator i = c.begin(); - assert(i[0] == 0); - TEST_LIBCPP_ASSERT_FAILURE(i[1], "Attempted to subscript an iterator outside its valid range"); - } + C c(1, '\0'); + C::iterator i = c.begin(); + assert(i[0] == 0); + TEST_LIBCPP_ASSERT_FAILURE(i[1], "Attempted to subscript an iterator outside its valid range"); +} + +int main(int, char**) { + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.subtract.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.subtract.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.subtract.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.iterators/debug.iterator.subtract.pass.cpp @@ -18,20 +18,16 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + S s1; + S s2; + TEST_LIBCPP_ASSERT_FAILURE(s1.begin() - s2.begin(), "Attempted to subtract incompatible iterators"); +} + int main(int, char**) { - { - typedef std::string S; - S s1; - S s2; - TEST_LIBCPP_ASSERT_FAILURE(s1.begin() - s2.begin(), "Attempted to subtract incompatible iterators"); - } - - { - typedef std::basic_string, min_allocator > S; - S s1; - S s2; - TEST_LIBCPP_ASSERT_FAILURE(s1.begin() - s2.begin(), "Attempted to subtract incompatible iterators"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.erase_iter.null.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.erase_iter.null.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.erase_iter.null.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.erase_iter.null.pass.cpp @@ -20,19 +20,16 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + S l1("123"); + typename S::const_iterator i = l1.end(); + TEST_LIBCPP_ASSERT_FAILURE(l1.erase(i), "string::erase(iterator) called with a non-dereferenceable iterator"); +} + int main(int, char**) { - { - typedef std::basic_string, min_allocator > S; - S l1("123"); - S::const_iterator i = l1.end(); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(i), "string::erase(iterator) called with a non-dereferenceable iterator"); - } - - { - std::string l1("123"); - std::string::const_iterator i = l1.end(); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(i), "string::erase(iterator) called with a non-dereferenceable iterator"); - } + test(); + test, min_allocator > >(); return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.pop_back.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.pop_back.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.pop_back.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/assert.pop_back.pass.cpp @@ -19,9 +19,14 @@ #include "check_assertion.h" +template +void test() { + S s; + TEST_LIBCPP_ASSERT_FAILURE(s.pop_back(), "string::pop_back(): string is already empty"); +} + int main(int, char**) { - std::string s; - TEST_LIBCPP_ASSERT_FAILURE(s.pop_back(), "string::pop_back(): string is already empty"); + test(); - return 0; + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter.pass.cpp @@ -18,21 +18,18 @@ #include "check_assertion.h" #include "min_allocator.h" +template +void test() { + S l1("123"); + S l2("123"); + typename S::const_iterator i = l2.begin(); + TEST_LIBCPP_ASSERT_FAILURE( + l1.erase(i), "string::erase(iterator) called with an iterator not referring to this string"); +} + int main(int, char**) { - { - std::string l1("123"); - std::string l2("123"); - std::string::const_iterator i = l2.begin(); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(i), "string::erase(iterator) called with an iterator not referring to this string"); - } - - { - typedef std::basic_string, min_allocator > S; - S l1("123"); - S l2("123"); - S::const_iterator i = l2.begin(); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(i), "string::erase(iterator) called with an iterator not referring to this string"); - } - - return 0; + test(); + test, min_allocator > >(); + + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter_iter.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter_iter.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter_iter.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.erase.iter_iter.pass.cpp @@ -18,74 +18,44 @@ #include "check_assertion.h" #include "min_allocator.h" -int main(int, char**) { - - // With first iterator from another container - { - { - std::string l1("123"); - std::string l2("123"); - TEST_LIBCPP_ASSERT_FAILURE( - l1.erase(l2.cbegin(), l1.cbegin() + 1), - "string::erase(iterator, iterator) called with an iterator not referring to this string"); - } - { - typedef std::basic_string, min_allocator > S; - S l1("123"); - S l2("123"); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(l2.cbegin(), l1.cbegin() + 1), - "string::erase(iterator, iterator) called with an iterator not referring to this string"); - } - } - - // With second iterator from another container - { - { - std::string l1("123"); - std::string l2("123"); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(l1.cbegin(), l2.cbegin() + 1), "Attempted to compare incomparable iterators"); - } - { - typedef std::basic_string, min_allocator > S; - S l1("123"); - S l2("123"); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(l1.cbegin(), l2.cbegin() + 1), "Attempted to compare incomparable iterators"); - } - } - - // With both iterators from another container - { - { - std::string l1("123"); - std::string l2("123"); - TEST_LIBCPP_ASSERT_FAILURE( - l1.erase(l2.cbegin(), l2.cbegin() + 1), - "string::erase(iterator, iterator) called with an iterator not referring to this string"); - } - { - typedef std::basic_string, min_allocator > S; - S l1("123"); - S l2("123"); - TEST_LIBCPP_ASSERT_FAILURE( - l1.erase(l2.cbegin(), l2.cbegin() + 1), - "string::erase(iterator, iterator) called with an iterator not referring to this string"); - } - } +template +void test() { + // With first iterator from another container + { + S l1("123"); + S l2("123"); + TEST_LIBCPP_ASSERT_FAILURE( + l1.erase(l2.cbegin(), l1.cbegin() + 1), + "string::erase(iterator, iterator) called with an iterator not referring to this string"); + } + + // With second iterator from another container + { + S l1("123"); + S l2("123"); + TEST_LIBCPP_ASSERT_FAILURE(l1.erase(l1.cbegin(), l2.cbegin() + 1), "Attempted to compare incomparable iterators"); + } + + // With both iterators from another container + { + S l1("123"); + S l2("123"); + TEST_LIBCPP_ASSERT_FAILURE( + l1.erase(l2.cbegin(), l2.cbegin() + 1), + "string::erase(iterator, iterator) called with an iterator not referring to this string"); + } + + // With an invalid range + { + S l1("123"); + TEST_LIBCPP_ASSERT_FAILURE( + l1.erase(l1.cbegin() + 1, l1.cbegin()), "string::erase(first, last) called with invalid range"); + } +} - // With an invalid range - { - { - std::string l1("123"); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(l1.cbegin() + 1, l1.cbegin()), - "string::erase(first, last) called with invalid range"); - } - { - typedef std::basic_string, min_allocator > S; - S l1("123"); - TEST_LIBCPP_ASSERT_FAILURE(l1.erase(l1.cbegin() + 1, l1.cbegin()), - "string::erase(first, last) called with invalid range"); - } - } +int main(int, char**) { + test(); + test, min_allocator > >(); - return 0; + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_char.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_char.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_char.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_char.pass.cpp @@ -23,12 +23,17 @@ #include "check_assertion.h" +template +void test() { + S s; + S s2; + TEST_LIBCPP_ASSERT_FAILURE( + s.insert(s2.begin(), '1'), + "string::insert(iterator, character) called with an iterator not referring to this string"); +} + int main(int, char**) { - typedef std::string S; - S s; - S s2; - TEST_LIBCPP_ASSERT_FAILURE(s.insert(s2.begin(), '1'), - "string::insert(iterator, character) called with an iterator not referring to this string"); + test(); - return 0; + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_iter_iter.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_iter_iter.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_iter_iter.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_iter_iter.pass.cpp @@ -18,13 +18,18 @@ #include "check_assertion.h" +template +void test() { + S v; + S v2; + char a[] = "123"; + const int N = sizeof(a) / sizeof(a[0]); + TEST_LIBCPP_ASSERT_FAILURE( + v.insert(v2.cbegin() + 10, a, a + N), "Attempted to add/subtract an iterator outside its valid range"); +} + int main(int, char**) { - std::string v; - std::string v2; - char a[] = "123"; - const int N = sizeof(a)/sizeof(a[0]); - TEST_LIBCPP_ASSERT_FAILURE(v.insert(v2.cbegin() + 10, a, a + N), - "Attempted to add/subtract an iterator outside its valid range"); - - return 0; + test(); + + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_size_char.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_size_char.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_size_char.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/debug.insert.iter_size_char.pass.cpp @@ -17,12 +17,16 @@ #include "check_assertion.h" +template +void test() { + S s; + S s2; + TEST_LIBCPP_ASSERT_FAILURE(s.insert(s2.begin(), 1, 'a'), + "string::insert(iterator, n, value) called with an iterator not referring to this string"); +} + int main(int, char**) { - std::string s; - std::string s2; - TEST_LIBCPP_ASSERT_FAILURE( - s.insert(s2.begin(), 1, 'a'), - "string::insert(iterator, n, value) called with an iterator not referring to this string"); + test(); - return 0; + return 0; } diff --git a/libcxx/test/libcxx/strings/basic.string/string.modifiers/resize_default_initialized.pass.cpp b/libcxx/test/libcxx/strings/basic.string/string.modifiers/resize_default_initialized.pass.cpp --- a/libcxx/test/libcxx/strings/basic.string/string.modifiers/resize_default_initialized.pass.cpp +++ b/libcxx/test/libcxx/strings/basic.string/string.modifiers/resize_default_initialized.pass.cpp @@ -15,19 +15,19 @@ #include "test_macros.h" -TEST_CONSTEXPR_CXX20 void write_c_str(char *buf, int size) { - for (int i=0; i < size; ++i) { +TEST_CONSTEXPR_CXX20 void write_c_str(char* buf, int size) { + for (int i = 0; i < size; ++i) { buf[i] = 'a'; } buf[size] = '\0'; } -TEST_CONSTEXPR_CXX20 void test_buffer_usage() -{ +template +TEST_CONSTEXPR_CXX20 void test_buffer_usage() { { unsigned buff_size = 125; unsigned used_size = buff_size - 16; - std::string s; + S s; s.__resize_default_init(buff_size); write_c_str(&s[0], used_size); assert(s.size() == buff_size); @@ -35,19 +35,20 @@ s.__resize_default_init(used_size); assert(s.size() == used_size); assert(s.data()[used_size] == '\0'); - for (unsigned i=0; i < used_size; ++i) { + for (unsigned i = 0; i < used_size; ++i) { assert(s[i] == 'a'); } } } +template TEST_CONSTEXPR_CXX20 void test_basic() { { - std::string s; + S s; s.__resize_default_init(3); assert(s.size() == 3); assert(s.data()[3] == '\0'); - for (int i=0; i < 3; ++i) + for (int i = 0; i < 3; ++i) s[i] = 'a' + i; s.__resize_default_init(1); assert(s[0] == 'a'); @@ -56,17 +57,18 @@ } } +template TEST_CONSTEXPR_CXX20 bool test() { - test_basic(); - test_buffer_usage(); + test_basic(); + test_buffer_usage(); return true; } int main(int, char**) { - test(); + test(); #if TEST_STD_VER > 17 - static_assert(test()); + static_assert(test()); #endif return 0; diff --git a/libcxx/test/std/strings/basic.string/string.capacity/capacity.pass.cpp b/libcxx/test/std/strings/basic.string/string.capacity/capacity.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.capacity/capacity.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.capacity/capacity.pass.cpp @@ -19,31 +19,34 @@ #include "test_macros.h" template -TEST_CONSTEXPR_CXX20 void -test(S s, test_allocator_statistics& alloc_stats) -{ - alloc_stats.throw_after = 0; +TEST_CONSTEXPR_CXX20 void test(S s, test_allocator_statistics& alloc_stats) { + alloc_stats.throw_after = 0; #ifndef TEST_HAS_NO_EXCEPTIONS - try + try #endif - { - while (s.size() < s.capacity()) - s.push_back(typename S::value_type()); - assert(s.size() == s.capacity()); - } + { + while (s.size() < s.capacity()) + s.push_back(typename S::value_type()); + assert(s.size() == s.capacity()); + } #ifndef TEST_HAS_NO_EXCEPTIONS - catch (...) - { - assert(false); - } + catch (...) { + assert(false); + } #endif - alloc_stats.throw_after = INT_MAX; + alloc_stats.throw_after = INT_MAX; +} + +template +TEST_CONSTEXPR_CXX20 void test_string() { + S s; + assert(s.capacity() > 0); } TEST_CONSTEXPR_CXX20 bool test() { { + using S = std::basic_string, test_allocator >; test_allocator_statistics alloc_stats; - typedef std::basic_string, test_allocator > S; S s((test_allocator(&alloc_stats))); test(s, alloc_stats); s.assign(10, 'a'); @@ -54,18 +57,13 @@ test(s, alloc_stats); } #if TEST_STD_VER >= 11 - { - typedef std::basic_string, min_allocator> S; - S s; - assert(s.capacity() > 0); - } + test_string, min_allocator > >(); #endif return true; } -int main(int, char**) -{ +int main(int, char**) { test(); #if TEST_STD_VER > 17 static_assert(test()); diff --git a/libcxx/test/std/strings/basic.string/string.capacity/max_size.pass.cpp b/libcxx/test/std/strings/basic.string/string.capacity/max_size.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.capacity/max_size.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.capacity/max_size.pass.cpp @@ -48,12 +48,10 @@ } template -TEST_CONSTEXPR_CXX20 void -test(const S& s) -{ - assert(s.max_size() >= s.size()); - test1(s); - test2(s); +TEST_CONSTEXPR_CXX20 void test(const S& s) { + assert(s.max_size() >= s.size()); + test1(s); + test2(s); } template @@ -63,28 +61,33 @@ test(S("12345678901234567890123456789012345678901234567890")); } -TEST_CONSTEXPR_CXX20 bool test() { +TEST_CONSTEXPR_CXX20 +bool test() { test_string(); #if TEST_STD_VER >= 11 - test_string, min_allocator>>(); + test_string, min_allocator > >(); #endif return true; } #if TEST_STD_VER > 17 -constexpr bool test_constexpr() { - std::string str; +template +TEST_CONSTEXPR_CXX20 void test_string_constexpr() { + S str; std::size_t size = str.max_size(); assert(size > 0); +} + +TEST_CONSTEXPR_CXX20 bool test_constexpr() { + test_string_constexpr(); return true; } #endif -int main(int, char**) -{ +int main(int, char**) { test(); #if TEST_STD_VER > 17 test_constexpr(); diff --git a/libcxx/test/std/strings/basic.string/string.capacity/over_max_size.pass.cpp b/libcxx/test/std/strings/basic.string/string.capacity/over_max_size.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.capacity/over_max_size.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.capacity/over_max_size.pass.cpp @@ -47,14 +47,13 @@ bool test() { test_string(); #if TEST_STD_VER >= 11 - test_string, min_allocator>>(); + test_string, min_allocator > >(); #endif return true; } -int main(int, char**) -{ +int main(int, char**) { test(); return 0; diff --git a/libcxx/test/std/strings/basic.string/string.capacity/resize_and_overwrite.pass.cpp b/libcxx/test/std/strings/basic.string/string.capacity/resize_and_overwrite.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.capacity/resize_and_overwrite.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.capacity/resize_and_overwrite.pass.cpp @@ -49,7 +49,7 @@ LIBCPP_ASSERT(s.begin().base() == p); assert(std::all_of(p, p + n, [](auto ch) { return ch == 'a'; })); p[n - 1] = 'b'; - p[n] = 'c'; // will be overwritten + p[n] = 'c'; // will be overwritten return n; }); const S expected = S(N - 1, 'a') + S(1, 'b'); @@ -57,19 +57,18 @@ assert(s.c_str()[N] == '\0'); } -template +template constexpr bool test() { - using S = std::basic_string; - test_appending(10, 15, 15); - test_appending(10, 15, 20); - test_appending(10, 40, 40); - test_appending(10, 40, 50); - test_appending(30, 35, 35); - test_appending(30, 35, 45); - test_appending(10, 15, 30); - test_truncating(15, 10); - test_truncating(40, 35); - test_truncating(40, 10); + test_appending(10, 15, 15); + test_appending(10, 15, 20); + test_appending(10, 40, 40); + test_appending(10, 40, 50); + test_appending(30, 35, 35); + test_appending(30, 35, 45); + test_appending(10, 15, 30); + test_truncating(15, 10); + test_truncating(40, 35); + test_truncating(40, 10); return true; } @@ -85,19 +84,19 @@ } int main(int, char**) { - test(); - test(); - test(); - test(); + test, std::allocator> >(); + test, std::allocator> >(); + test, std::allocator> >(); + test, std::allocator> >(); - static_assert(test()); - static_assert(test()); - static_assert(test()); - static_assert(test()); + static_assert(test, std::allocator> >()); + static_assert(test, std::allocator> >()); + static_assert(test, std::allocator> >()); + static_assert(test, std::allocator> >()); #ifndef TEST_HAS_NO_WIDE_CHARACTERS - test(); - static_assert(test()); + test, std::allocator> >(); + static_assert(test, std::allocator> >()); #endif return 0; } diff --git a/libcxx/test/std/strings/basic.string/string.cons/T_size_size.pass.cpp b/libcxx/test/std/strings/basic.string/string.cons/T_size_size.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.cons/T_size_size.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.cons/T_size_size.pass.cpp @@ -25,168 +25,156 @@ #include "min_allocator.h" template -TEST_CONSTEXPR_CXX20 void -test(SV sv, std::size_t pos, std::size_t n) -{ - typedef typename S::traits_type T; - typedef typename S::allocator_type A; - typedef typename S::size_type Size; - if (pos <= sv.size()) - { - S s2(sv, static_cast(pos), static_cast(n)); - LIBCPP_ASSERT(s2.__invariants()); - assert(pos <= sv.size()); - std::size_t rlen = std::min(sv.size() - pos, n); - assert(s2.size() == rlen); - assert(T::compare(s2.data(), sv.data() + pos, rlen) == 0); - assert(s2.get_allocator() == A()); - assert(s2.capacity() >= s2.size()); - } +TEST_CONSTEXPR_CXX20 void test(SV sv, std::size_t pos, std::size_t n) { + typedef typename S::traits_type T; + typedef typename S::allocator_type A; + typedef typename S::size_type Size; + if (pos <= sv.size()) { + S s2(sv, static_cast(pos), static_cast(n)); + LIBCPP_ASSERT(s2.__invariants()); + assert(pos <= sv.size()); + std::size_t rlen = std::min(sv.size() - pos, n); + assert(s2.size() == rlen); + assert(T::compare(s2.data(), sv.data() + pos, rlen) == 0); + assert(s2.get_allocator() == A()); + assert(s2.capacity() >= s2.size()); + } #ifndef TEST_HAS_NO_EXCEPTIONS - else if (!TEST_IS_CONSTANT_EVALUATED) - { - try - { - S s2(sv, static_cast(pos), static_cast(n)); - assert(false); - } - catch (std::out_of_range&) - { - assert(pos > sv.size()); - } + else if (!TEST_IS_CONSTANT_EVALUATED) { + try { + S s2(sv, static_cast(pos), static_cast(n)); + assert(false); + } catch (std::out_of_range&) { + assert(pos > sv.size()); } + } #endif } template -TEST_CONSTEXPR_CXX20 void -test(SV sv, std::size_t pos, std::size_t n, const typename S::allocator_type& a) -{ - typedef typename S::traits_type T; - typedef typename S::size_type Size; - if (pos <= sv.size()) - { - S s2(sv, static_cast(pos), static_cast(n), a); - LIBCPP_ASSERT(s2.__invariants()); - assert(pos <= sv.size()); - std::size_t rlen = std::min(sv.size() - pos, n); - assert(s2.size() == rlen); - assert(T::compare(s2.data(), sv.data() + pos, rlen) == 0); - assert(s2.get_allocator() == a); - assert(s2.capacity() >= s2.size()); - } +TEST_CONSTEXPR_CXX20 void test(SV sv, std::size_t pos, std::size_t n, const typename S::allocator_type& a) { + typedef typename S::traits_type T; + typedef typename S::size_type Size; + if (pos <= sv.size()) { + S s2(sv, static_cast(pos), static_cast(n), a); + LIBCPP_ASSERT(s2.__invariants()); + assert(pos <= sv.size()); + std::size_t rlen = std::min(sv.size() - pos, n); + assert(s2.size() == rlen); + assert(T::compare(s2.data(), sv.data() + pos, rlen) == 0); + assert(s2.get_allocator() == a); + assert(s2.capacity() >= s2.size()); + } #ifndef TEST_HAS_NO_EXCEPTIONS - else if (!TEST_IS_CONSTANT_EVALUATED) - { - try - { - S s2(sv, static_cast(pos), static_cast(n), a); - assert(false); - } - catch (std::out_of_range&) - { - assert(pos > sv.size()); - } + else if (!TEST_IS_CONSTANT_EVALUATED) { + try { + S s2(sv, static_cast(pos), static_cast(n), a); + assert(false); + } catch (std::out_of_range&) { + assert(pos > sv.size()); } + } #endif } +template class Alloc> +TEST_CONSTEXPR_CXX20 void test_string() { + using A = Alloc; + using S = std::basic_string, A>; + using SV = std::basic_string_view< CharT, std::char_traits >; + + test(SV(), 0, 0); + test(SV(), 0, 1); + test(SV(), 1, 0); + test(SV(), 1, 1); + test(SV(), 1, 2); + test(SV("1"), 0, 0); + test(SV("1"), 0, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100); + + test(SV(), 0, 0, A()); + test(SV(), 0, 1, A()); + test(SV(), 1, 0, A()); + test(SV(), 1, 1, A()); + test(SV(), 1, 2, A()); + test(SV("1"), 0, 0, A()); + test(SV("1"), 0, 1, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100, A()); +} + TEST_CONSTEXPR_CXX20 bool test() { { typedef test_allocator A; typedef std::basic_string_view > SV; - typedef std::basic_string , A> S; - - test(SV(), 0, 0); - test(SV(), 0, 1); - test(SV(), 1, 0); - test(SV(), 1, 1); - test(SV(), 1, 2); - test(SV("1"), 0, 0); - test(SV("1"), 0, 1); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100); - - test(SV(), 0, 0, A(4)); - test(SV(), 0, 1, A(4)); - test(SV(), 1, 0, A(4)); - test(SV(), 1, 1, A(4)); - test(SV(), 1, 2, A(4)); - test(SV("1"), 0, 0, A(6)); - test(SV("1"), 0, 1, A(6)); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0, A(8)); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1, A(8)); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10, A(8)); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100, A(8)); + typedef std::basic_string, A> S; + + test(SV(), 0, 0); + test(SV(), 0, 1); + test(SV(), 1, 0); + test(SV(), 1, 1); + test(SV(), 1, 2); + test(SV("1"), 0, 0); + test(SV("1"), 0, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100); + + test(SV(), 0, 0, A(4)); + test(SV(), 0, 1, A(4)); + test(SV(), 1, 0, A(4)); + test(SV(), 1, 1, A(4)); + test(SV(), 1, 2, A(4)); + test(SV("1"), 0, 0, A(6)); + test(SV("1"), 0, 1, A(6)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0, A(8)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1, A(8)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10, A(8)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100, A(8)); } #if TEST_STD_VER >= 11 - { - typedef min_allocator A; - typedef std::basic_string_view > SV; - typedef std::basic_string , A> S; - - test(SV(), 0, 0); - test(SV(), 0, 1); - test(SV(), 1, 0); - test(SV(), 1, 1); - test(SV(), 1, 2); - test(SV("1"), 0, 0); - test(SV("1"), 0, 1); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100); - - test(SV(), 0, 0, A()); - test(SV(), 0, 1, A()); - test(SV(), 1, 0, A()); - test(SV(), 1, 1, A()); - test(SV(), 1, 2, A()); - test(SV("1"), 0, 0, A()); - test(SV("1"), 0, 1, A()); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0, A()); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1, A()); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10, A()); - test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100, A()); - } + test_string(); #endif { typedef std::string S; typedef std::string_view SV; - S s = "ABCD"; - SV sv = "EFGH"; + S s = "ABCD"; + SV sv = "EFGH"; char arr[] = "IJKL"; - S s1("CDEF", 4); // calls ctor(const char *, len) + S s1("CDEF", 4); // calls ctor(const char *, len) assert(s1 == "CDEF"); S s2("QRST", 0, 3); // calls ctor(string("QRST", pos, len) assert(s2 == "QRS"); - S s3(sv, 0, std::string::npos); // calls ctor(T, pos, npos) + S s3(sv, 0, std::string::npos); // calls ctor(T, pos, npos) assert(s3 == sv); - S s4(sv, 0, 3); // calls ctor(T, pos, len) + S s4(sv, 0, 3); // calls ctor(T, pos, len) assert(s4 == "EFG"); - S s5(arr, 0, 2); // calls ctor(const char *, len) + S s5(arr, 0, 2); // calls ctor(const char *, len) assert(s5 == "IJ"); - S s6(arr, 0); // calls ctor(const char *, len) + S s6(arr, 0); // calls ctor(const char *, len) assert(s6 == ""); - S s7(s.data(), 2); // calls ctor(const char *, len) + S s7(s.data(), 2); // calls ctor(const char *, len) assert(s7 == "AB"); } return true; } -int main(int, char**) -{ +int main(int, char**) { test(); #if TEST_STD_VER > 17 static_assert(test()); diff --git a/libcxx/test/std/strings/basic.string/string.cons/copy.pass.cpp b/libcxx/test/std/strings/basic.string/string.cons/copy.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.cons/copy.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.cons/copy.pass.cpp @@ -18,39 +18,39 @@ #include "min_allocator.h" template -TEST_CONSTEXPR_CXX20 void -test(S s1) -{ - S s2 = s1; - LIBCPP_ASSERT(s2.__invariants()); - assert(s2 == s1); - assert(s2.capacity() >= s2.size()); - assert(s2.get_allocator() == s1.get_allocator()); +TEST_CONSTEXPR_CXX20 void test(S s1) { + S s2 = s1; + LIBCPP_ASSERT(s2.__invariants()); + assert(s2 == s1); + assert(s2.capacity() >= s2.size()); + assert(s2.get_allocator() == s1.get_allocator()); +} + +template class Alloc> +TEST_CONSTEXPR_CXX20 void test_string() { + using A = Alloc; + using S = std::basic_string, A>; + test(S(A())); + test(S("1", A())); + test(S("1234567890123456789012345678901234567890123456789012345678901234567890", A())); } TEST_CONSTEXPR_CXX20 bool test() { { - typedef test_allocator A; - typedef std::basic_string, A> S; + using A = test_allocator; + using S = std::basic_string, A>; test(S(A(3))); test(S("1", A(5))); test(S("1234567890123456789012345678901234567890123456789012345678901234567890", A(7))); } #if TEST_STD_VER >= 11 - { - typedef min_allocator A; - typedef std::basic_string, A> S; - test(S(A{})); - test(S("1", A())); - test(S("1234567890123456789012345678901234567890123456789012345678901234567890", A())); - } + test_string(); #endif return true; } -int main(int, char**) -{ +int main(int, char**) { test(); #if TEST_STD_VER > 17 static_assert(test()); diff --git a/libcxx/test/std/strings/basic.string/string.cons/copy_alloc.pass.cpp b/libcxx/test/std/strings/basic.string/string.cons/copy_alloc.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.cons/copy_alloc.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.cons/copy_alloc.pass.cpp @@ -19,98 +19,98 @@ #ifndef TEST_HAS_NO_EXCEPTIONS struct alloc_imp { - bool active; - - TEST_CONSTEXPR alloc_imp() : active(true) {} - - template - T* allocate(std::size_t n) - { - if (active) - return static_cast(std::malloc(n * sizeof(T))); - else - throw std::bad_alloc(); - } - - template - void deallocate(T* p, std::size_t) { std::free(p); } - void activate () { active = true; } - void deactivate() { active = false; } + bool active; + + TEST_CONSTEXPR alloc_imp() : active(true) {} + + template + T* allocate(std::size_t n) { + if (active) + return static_cast(std::malloc(n * sizeof(T))); + else + throw std::bad_alloc(); + } + + template + void deallocate(T* p, std::size_t) { + std::free(p); + } + void activate() { active = true; } + void deactivate() { active = false; } }; template struct poca_alloc { - typedef T value_type; - typedef std::true_type propagate_on_container_copy_assignment; + typedef T value_type; + typedef std::true_type propagate_on_container_copy_assignment; - alloc_imp *imp; + alloc_imp* imp; - TEST_CONSTEXPR poca_alloc(alloc_imp *imp_) : imp (imp_) {} + TEST_CONSTEXPR poca_alloc(alloc_imp* imp_) : imp(imp_) {} - template - TEST_CONSTEXPR poca_alloc(const poca_alloc& other) : imp(other.imp) {} + template + TEST_CONSTEXPR poca_alloc(const poca_alloc& other) : imp(other.imp) {} - T* allocate (std::size_t n) { return imp->allocate(n);} - void deallocate(T* p, std::size_t n) { imp->deallocate(p, n); } + T* allocate(std::size_t n) { return imp->allocate(n); } + void deallocate(T* p, std::size_t n) { imp->deallocate(p, n); } }; template -bool operator==(const poca_alloc& lhs, const poca_alloc& rhs) -{ - return lhs.imp == rhs.imp; +bool operator==(const poca_alloc& lhs, const poca_alloc& rhs) { + return lhs.imp == rhs.imp; } template -bool operator!=(const poca_alloc& lhs, const poca_alloc& rhs) -{ - return lhs.imp != rhs.imp; +bool operator!=(const poca_alloc& lhs, const poca_alloc& rhs) { + return lhs.imp != rhs.imp; } template -TEST_CONSTEXPR_CXX20 void test_assign(S &s1, const S& s2) -{ - try { s1 = s2; } - catch ( std::bad_alloc &) { return; } - assert(false); +TEST_CONSTEXPR_CXX20 void test_assign(S& s1, const S& s2) { + try { + s1 = s2; + } catch (std::bad_alloc&) { + return; + } + assert(false); } #endif - - template -TEST_CONSTEXPR_CXX20 void -test(S s1, const typename S::allocator_type& a) -{ - S s2(s1, a); - LIBCPP_ASSERT(s2.__invariants()); - assert(s2 == s1); - assert(s2.capacity() >= s2.size()); - assert(s2.get_allocator() == a); +TEST_CONSTEXPR_CXX20 void test(S s1, const typename S::allocator_type& a) { + S s2(s1, a); + LIBCPP_ASSERT(s2.__invariants()); + assert(s2 == s1); + assert(s2.capacity() >= s2.size()); + assert(s2.get_allocator() == a); +} + +template class Alloc> +TEST_CONSTEXPR_CXX20 void test_string() { + using A = Alloc; + using S = std::basic_string, A>; + test(S(), A()); + test(S("1"), A()); + test(S("1234567890123456789012345678901234567890123456789012345678901234567890"), A()); } TEST_CONSTEXPR_CXX20 bool test() { { - typedef test_allocator A; - typedef std::basic_string, A> S; + using A = test_allocator; + using S = std::basic_string, A>; test(S(), A(3)); test(S("1"), A(5)); test(S("1234567890123456789012345678901234567890123456789012345678901234567890"), A(7)); } #if TEST_STD_VER >= 11 - { - typedef min_allocator A; - typedef std::basic_string, A> S; - test(S(), A()); - test(S("1"), A()); - test(S("1234567890123456789012345678901234567890123456789012345678901234567890"), A()); - } + test_string(); -#ifndef TEST_HAS_NO_EXCEPTIONS +# ifndef TEST_HAS_NO_EXCEPTIONS if (!TEST_IS_CONSTANT_EVALUATED) { typedef poca_alloc A; typedef std::basic_string, A> S; - const char * p1 = "This is my first string"; - const char * p2 = "This is my second string"; + const char* p1 = "This is my first string"; + const char* p2 = "This is my second string"; alloc_imp imp1; alloc_imp imp2; @@ -125,14 +125,13 @@ assert(s1 == p1); assert(s2 == p2); } -#endif +# endif #endif return true; } -int main(int, char**) -{ +int main(int, char**) { test(); #if TEST_STD_VER > 17 static_assert(test()); diff --git a/libcxx/test/std/strings/basic.string/string.cons/initializer_list.pass.cpp b/libcxx/test/std/strings/basic.string/string.cons/initializer_list.pass.cpp --- a/libcxx/test/std/strings/basic.string/string.cons/initializer_list.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.cons/initializer_list.pass.cpp @@ -19,37 +19,28 @@ #include "test_allocator.h" #include "min_allocator.h" -TEST_CONSTEXPR_CXX20 bool test() { - { - std::string s = {'a', 'b', 'c'}; - assert(s == "abc"); - } -#ifndef TEST_HAS_NO_WIDE_CHARACTERS - { - std::wstring s; - s = {L'a', L'b', L'c'}; - assert(s == L"abc"); - } -#endif - { - typedef std::basic_string, min_allocator> S; - S s = {'a', 'b', 'c'}; - assert(s == "abc"); - } +template