From b7332b04df5d50c92640c74cfeb138ecb7e3f7ae Mon Sep 17 00:00:00 2001 From: Dimitry Andric Date: Tue, 20 Aug 2019 18:01:01 +0000 Subject: Remove upstream files and directories from vendor/libc++/dist that we do not use. This saves on repository space, and reduces the number of tree conflicts when merging. --- .../func.wrap.func.con/F_assign.pass.cpp | 119 --------------------- 1 file changed, 119 deletions(-) delete mode 100644 test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F_assign.pass.cpp (limited to 'test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F_assign.pass.cpp') diff --git a/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F_assign.pass.cpp b/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F_assign.pass.cpp deleted file mode 100644 index e927ad42c06b..000000000000 --- a/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F_assign.pass.cpp +++ /dev/null @@ -1,119 +0,0 @@ -//===----------------------------------------------------------------------===// -// -// 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. -// -//===----------------------------------------------------------------------===// - -// - -// class function - -// template -// requires CopyConstructible && Callable -// && Convertible::result_type -// operator=(F f); - -#include -#include - -#include "test_macros.h" -#include "count_new.hpp" - -class A -{ - int data_[10]; -public: - static int count; - - A() - { - ++count; - for (int i = 0; i < 10; ++i) - data_[i] = i; - } - - A(const A&) {++count;} - - ~A() {--count;} - - int operator()(int i) const - { - for (int j = 0; j < 10; ++j) - i += data_[j]; - return i; - } - - int foo(int) const {return 1;} -}; - -int A::count = 0; - -int g(int) {return 0;} - -#if TEST_STD_VER >= 11 -struct RValueCallable { - template - void operator()(Args&&...) && {} -}; -struct LValueCallable { - template - void operator()(Args&&...) & {} -}; -#endif - -int main() -{ - assert(globalMemCounter.checkOutstandingNewEq(0)); - { - std::function f; - f = A(); - assert(A::count == 1); - assert(globalMemCounter.checkOutstandingNewEq(1)); - assert(f.target()); - assert(f.target() == 0); - } - assert(A::count == 0); - assert(globalMemCounter.checkOutstandingNewEq(0)); - { - std::function f; - f = g; - assert(globalMemCounter.checkOutstandingNewEq(0)); - assert(f.target()); - assert(f.target() == 0); - } - assert(globalMemCounter.checkOutstandingNewEq(0)); - { - std::function f; - f = (int (*)(int))0; - assert(!f); - assert(globalMemCounter.checkOutstandingNewEq(0)); - assert(f.target() == 0); - assert(f.target() == 0); - } - { - std::function f; - f = &A::foo; - assert(f); - assert(globalMemCounter.checkOutstandingNewEq(0)); - assert(f.target() != 0); - } - { - std::function f; - f = &g; - assert(f); - assert(f.target() != 0); - f(1); - } -#if TEST_STD_VER >= 11 - { - using Fn = std::function; - static_assert(std::is_assignable::value, ""); - static_assert(std::is_assignable::value, ""); - static_assert(!std::is_assignable::value, ""); - static_assert(!std::is_assignable::value, ""); - } -#endif -} -- cgit v1.3