//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // // class function // template // requires Callable && Convertible::result_type, R> // T* // target(); // template // requires Callable && Convertible::result_type, R> // const T* // target() const; #include #include #include #include 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;} int main(int, char**) { { std::function f = A(); assert(A::count == 1); assert(f.target()); assert(f.target() == 0); assert(f.target() == nullptr); } assert(A::count == 0); { std::function f = g; assert(A::count == 0); assert(f.target()); assert(f.target() == 0); assert(f.target() == nullptr); } assert(A::count == 0); { const std::function f = A(); assert(A::count == 1); assert(f.target()); assert(f.target() == 0); assert(f.target() == nullptr); } assert(A::count == 0); { const std::function f = g; assert(A::count == 0); assert(f.target()); assert(f.target() == 0); assert(f.target() == nullptr); } assert(A::count == 0); return 0; }