//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03 // // class function // function& operator=(const function& f); #include #include #include #include "test_macros.h" #include "count_new.h" 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 A::count = 0; int g0() { return 0; } int g(int) { return 0; } int g2(int, int) { return 2; } int g3(int, int, int) { return 3; } int main(int, char**) { globalMemCounter.reset(); assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function f = A(); assert(A::count == 1); assert(globalMemCounter.checkOutstandingNewLessThanOrEqual(1)); RTTI_ASSERT(f.target()); RTTI_ASSERT(f.target() == 0); std::function f2; f2 = f; assert(A::count == 2); assert(globalMemCounter.checkOutstandingNewLessThanOrEqual(2)); RTTI_ASSERT(f2.target()); RTTI_ASSERT(f2.target() == 0); } assert(A::count == 0); assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function f = g; assert(globalMemCounter.checkOutstandingNewEq(0)); RTTI_ASSERT(f.target()); RTTI_ASSERT(f.target() == 0); std::function f2; f2 = f; assert(globalMemCounter.checkOutstandingNewEq(0)); RTTI_ASSERT(f2.target()); RTTI_ASSERT(f2.target() == 0); } assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function f; assert(globalMemCounter.checkOutstandingNewEq(0)); RTTI_ASSERT(f.target() == 0); RTTI_ASSERT(f.target() == 0); std::function f2; f2 = f; assert(globalMemCounter.checkOutstandingNewEq(0)); RTTI_ASSERT(f2.target() == 0); RTTI_ASSERT(f2.target() == 0); } { typedef std::function Func; Func f = g0; Func& fr = (f = (Func &)f); assert(&fr == &f); RTTI_ASSERT(*f.target() == g0); } { typedef std::function Func; Func f = g; Func& fr = (f = (Func &)f); assert(&fr == &f); RTTI_ASSERT(*f.target() == g); } { typedef std::function Func; Func f = g2; Func& fr = (f = (Func &)f); assert(&fr == &f); RTTI_ASSERT(*f.target() == g2); } { typedef std::function Func; Func f = g3; Func& fr = (f = (Func &)f); assert(&fr == &f); RTTI_ASSERT(*f.target() == g3); } #if TEST_STD_VER >= 11 assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function f = A(); assert(A::count == 1); assert(globalMemCounter.checkOutstandingNewLessThanOrEqual(1)); RTTI_ASSERT(f.target()); RTTI_ASSERT(f.target() == 0); std::function f2; f2 = std::move(f); assert(A::count == 1); assert(globalMemCounter.checkOutstandingNewLessThanOrEqual(1)); RTTI_ASSERT(f2.target()); RTTI_ASSERT(f2.target() == 0); RTTI_ASSERT(f.target() == 0); RTTI_ASSERT(f.target() == 0); } #endif return 0; }