libcxx

libcxx mirror with random patches
git clone https://git.neptards.moe/neptards/libcxx.git
Log | Files | Refs

F.pass.cpp (2749B)


      1 //===----------------------------------------------------------------------===//
      2 //
      3 //                     The LLVM Compiler Infrastructure
      4 //
      5 // This file is dual licensed under the MIT and the University of Illinois Open
      6 // Source Licenses. See LICENSE.TXT for details.
      7 //
      8 //===----------------------------------------------------------------------===//
      9 
     10 // <functional>
     11 
     12 // class function<R(ArgTypes...)>
     13 
     14 // function(F);
     15 
     16 #include <functional>
     17 #include <cassert>
     18 
     19 #include "test_macros.h"
     20 #include "count_new.hpp"
     21 
     22 class A
     23 {
     24     int data_[10];
     25 public:
     26     static int count;
     27 
     28     A()
     29     {
     30         ++count;
     31         for (int i = 0; i < 10; ++i)
     32             data_[i] = i;
     33     }
     34 
     35     A(const A&) {++count;}
     36 
     37     ~A() {--count;}
     38 
     39     int operator()(int i) const
     40     {
     41         for (int j = 0; j < 10; ++j)
     42             i += data_[j];
     43         return i;
     44     }
     45 
     46     int foo(int) const {return 1;}
     47 };
     48 
     49 int A::count = 0;
     50 
     51 int g(int) {return 0;}
     52 
     53 #if TEST_STD_VER >= 11
     54 struct RValueCallable {
     55     template <class ...Args>
     56     void operator()(Args&&...) && {}
     57 };
     58 struct LValueCallable {
     59     template <class ...Args>
     60     void operator()(Args&&...) & {}
     61 };
     62 #endif
     63 
     64 int main()
     65 {
     66     assert(globalMemCounter.checkOutstandingNewEq(0));
     67     {
     68     std::function<int(int)> f = A();
     69     assert(A::count == 1);
     70     assert(globalMemCounter.checkOutstandingNewEq(1));
     71     assert(f.target<A>());
     72     assert(f.target<int(*)(int)>() == 0);
     73     }
     74     assert(A::count == 0);
     75     assert(globalMemCounter.checkOutstandingNewEq(0));
     76     {
     77     std::function<int(int)> f = g;
     78     assert(globalMemCounter.checkOutstandingNewEq(0));
     79     assert(f.target<int(*)(int)>());
     80     assert(f.target<A>() == 0);
     81     }
     82     assert(globalMemCounter.checkOutstandingNewEq(0));
     83     {
     84     std::function<int(int)> f = (int (*)(int))0;
     85     assert(!f);
     86     assert(globalMemCounter.checkOutstandingNewEq(0));
     87     assert(f.target<int(*)(int)>() == 0);
     88     assert(f.target<A>() == 0);
     89     }
     90     {
     91     std::function<int(const A*, int)> f = &A::foo;
     92     assert(f);
     93     assert(globalMemCounter.checkOutstandingNewEq(0));
     94     assert(f.target<int (A::*)(int) const>() != 0);
     95     }
     96     {
     97       std::function<void(int)> f(&g);
     98       assert(f);
     99       assert(f.target<int(*)(int)>() != 0);
    100       f(1);
    101     }
    102     {
    103         std::function <void()> f(static_cast<void (*)()>(0));
    104         assert(!f);
    105     }
    106 #if TEST_STD_VER >= 11
    107     {
    108         using Fn = std::function<void(int, int, int)>;
    109         static_assert(std::is_constructible<Fn, LValueCallable&>::value, "");
    110         static_assert(std::is_constructible<Fn, LValueCallable>::value, "");
    111         static_assert(!std::is_constructible<Fn, RValueCallable&>::value, "");
    112         static_assert(!std::is_constructible<Fn, RValueCallable>::value, "");
    113     }
    114 #endif
    115 }