Add tests for match_results copy/move assignment operators. NFC
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@344998 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
50
test/std/re/re.results/re.results.const/copy_assign.pass.cpp
Normal file
50
test/std/re/re.results/re.results.const/copy_assign.pass.cpp
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <regex>
|
||||||
|
|
||||||
|
// class match_results<BidirectionalIterator, Allocator>
|
||||||
|
|
||||||
|
// match_results& operator=(const match_results& m);
|
||||||
|
|
||||||
|
#include <regex>
|
||||||
|
#include <cassert>
|
||||||
|
#include "test_macros.h"
|
||||||
|
#include "test_allocator.h"
|
||||||
|
|
||||||
|
template <class CharT, class Allocator>
|
||||||
|
void
|
||||||
|
test(const Allocator& a)
|
||||||
|
{
|
||||||
|
typedef std::match_results<const CharT*, Allocator> SM;
|
||||||
|
SM m0(a);
|
||||||
|
SM m1;
|
||||||
|
|
||||||
|
m1 = m0;
|
||||||
|
assert(m1.size() == m0.size());
|
||||||
|
assert(m1.str() == m0.str());
|
||||||
|
if (std::allocator_traits<Allocator>::propagate_on_container_copy_assignment::value)
|
||||||
|
assert(m1.get_allocator() == m0.get_allocator());
|
||||||
|
else
|
||||||
|
assert(m1.get_allocator() == Allocator());
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
test<char> (std::allocator<std::sub_match<const char *> >());
|
||||||
|
test<wchar_t>(std::allocator<std::sub_match<const wchar_t *> >());
|
||||||
|
|
||||||
|
// test_allocator has POCCA -> false
|
||||||
|
test<char> (test_allocator<std::sub_match<const char*> >(3));
|
||||||
|
test<wchar_t>(test_allocator<std::sub_match<const wchar_t*> >(3));
|
||||||
|
|
||||||
|
// other_allocator has POCCA -> true
|
||||||
|
test<char> (other_allocator<std::sub_match<const char*> >(3));
|
||||||
|
test<wchar_t>(other_allocator<std::sub_match<const wchar_t*> >(3));
|
||||||
|
}
|
||||||
@@ -12,6 +12,8 @@
|
|||||||
// class match_results<BidirectionalIterator, Allocator>
|
// class match_results<BidirectionalIterator, Allocator>
|
||||||
|
|
||||||
// match_results(match_results&& m) noexcept;
|
// match_results(match_results&& m) noexcept;
|
||||||
|
//
|
||||||
|
// Additionally, the stored Allocator value is move constructed from m.get_allocator().
|
||||||
|
|
||||||
#include <regex>
|
#include <regex>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
@@ -26,6 +28,8 @@ test(const Allocator& a)
|
|||||||
ASSERT_NOEXCEPT(SM(std::declval<SM&&>()));
|
ASSERT_NOEXCEPT(SM(std::declval<SM&&>()));
|
||||||
|
|
||||||
SM m0(a);
|
SM m0(a);
|
||||||
|
assert(m0.get_allocator() == a);
|
||||||
|
|
||||||
SM m1(std::move(m0));
|
SM m1(std::move(m0));
|
||||||
assert(m1.size() == 0);
|
assert(m1.size() == 0);
|
||||||
assert(m1.str() == std::basic_string<CharT>());
|
assert(m1.str() == std::basic_string<CharT>());
|
||||||
@@ -38,5 +42,7 @@ int main()
|
|||||||
test<wchar_t>(std::allocator<std::sub_match<const wchar_t *> >());
|
test<wchar_t>(std::allocator<std::sub_match<const wchar_t *> >());
|
||||||
|
|
||||||
test<char> (test_allocator<std::sub_match<const char*> >(3));
|
test<char> (test_allocator<std::sub_match<const char*> >(3));
|
||||||
|
assert(test_alloc_base::moved == 1);
|
||||||
test<wchar_t>(test_allocator<std::sub_match<const wchar_t*> >(3));
|
test<wchar_t>(test_allocator<std::sub_match<const wchar_t*> >(3));
|
||||||
|
assert(test_alloc_base::moved == 2);
|
||||||
}
|
}
|
||||||
|
|||||||
50
test/std/re/re.results/re.results.const/move_assign.pass.cpp
Normal file
50
test/std/re/re.results/re.results.const/move_assign.pass.cpp
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <regex>
|
||||||
|
|
||||||
|
// class match_results<BidirectionalIterator, Allocator>
|
||||||
|
|
||||||
|
// match_results& operator=(match_results&& m);
|
||||||
|
|
||||||
|
#include <regex>
|
||||||
|
#include <cassert>
|
||||||
|
#include "test_macros.h"
|
||||||
|
#include "test_allocator.h"
|
||||||
|
|
||||||
|
template <class CharT, class Allocator>
|
||||||
|
void
|
||||||
|
test(const Allocator& a)
|
||||||
|
{
|
||||||
|
typedef std::match_results<const CharT*, Allocator> SM;
|
||||||
|
SM m0(a);
|
||||||
|
SM m1;
|
||||||
|
|
||||||
|
m1 = std::move(m0);
|
||||||
|
assert(m1.size() == 0);
|
||||||
|
assert(m1.str() == std::basic_string<CharT>());
|
||||||
|
if (std::allocator_traits<Allocator>::propagate_on_container_move_assignment::value)
|
||||||
|
assert(m1.get_allocator() == a);
|
||||||
|
else
|
||||||
|
assert(m1.get_allocator() == Allocator());
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
test<char> (std::allocator<std::sub_match<const char *> >());
|
||||||
|
test<wchar_t>(std::allocator<std::sub_match<const wchar_t *> >());
|
||||||
|
|
||||||
|
// test_allocator has POCMA -> false
|
||||||
|
test<char> (test_allocator<std::sub_match<const char*> >(3));
|
||||||
|
test<wchar_t>(test_allocator<std::sub_match<const wchar_t*> >(3));
|
||||||
|
|
||||||
|
// other_allocator has POCMA -> true
|
||||||
|
test<char> (other_allocator<std::sub_match<const char*> >(3));
|
||||||
|
test<wchar_t>(other_allocator<std::sub_match<const wchar_t*> >(3));
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user