summaryrefslogtreecommitdiffstats
path: root/libcxx/test/std
diff options
context:
space:
mode:
authorEric Fiselier <eric@efcs.ca>2016-07-11 19:57:13 +0000
committerEric Fiselier <eric@efcs.ca>2016-07-11 19:57:13 +0000
commit0774aa96dc60c889a54d4d22850526d999f491a3 (patch)
tree27a6fbee6bd4f8efdde05df69fe6c13de634cda4 /libcxx/test/std
parentfaaeaaf0d8ee2d195ac1d3ba2c399cbaaa3944d6 (diff)
downloadbcm5719-llvm-0774aa96dc60c889a54d4d22850526d999f491a3.tar.gz
bcm5719-llvm-0774aa96dc60c889a54d4d22850526d999f491a3.zip
Allow is_swappable to SFINAE on deleted/ambiguous swap functions
llvm-svn: 275094
Diffstat (limited to 'libcxx/test/std')
-rw-r--r--libcxx/test/std/utilities/meta/meta.unary/meta.unary.prop/is_swappable.pass.cpp21
1 files changed, 21 insertions, 0 deletions
diff --git a/libcxx/test/std/utilities/meta/meta.unary/meta.unary.prop/is_swappable.pass.cpp b/libcxx/test/std/utilities/meta/meta.unary/meta.unary.prop/is_swappable.pass.cpp
index 9d01128379a..b17ca76fd58 100644
--- a/libcxx/test/std/utilities/meta/meta.unary/meta.unary.prop/is_swappable.pass.cpp
+++ b/libcxx/test/std/utilities/meta/meta.unary/meta.unary.prop/is_swappable.pass.cpp
@@ -49,8 +49,21 @@ struct M {
void swap(M&&, M&&) {}
+struct DeletedSwap {
+ friend void swap(DeletedSwap&, DeletedSwap&) = delete;
+};
+
} // namespace MyNS
+namespace MyNS2 {
+
+struct AmbiguousSwap {};
+
+template <class T>
+void swap(T&, T&) {}
+
+} // end namespace MyNS2
+
int main()
{
using namespace MyNS;
@@ -70,6 +83,14 @@ int main()
static_assert(!std::is_swappable<int() &>::value, "");
}
{
+ // test that a deleted swap is correctly handled.
+ static_assert(!std::is_swappable<DeletedSwap>::value, "");
+ }
+ {
+ // test that a swap with ambiguous overloads is handled correctly.
+ static_assert(!std::is_swappable<MyNS2::AmbiguousSwap>::value, "");
+ }
+ {
// test for presence of is_swappable_v
static_assert(std::is_swappable_v<int>, "");
static_assert(!std::is_swappable_v<M>, "");
OpenPOWER on IntegriCloud