alloc_rfunction.pass.cpp revision 1b92188a82b01e76ac6e8ad5f997293c2a078adc
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// template<class A> function(allocator_arg_t, const A&, function&&);
15
16#include <functional>
17#include <cassert>
18
19#include "test_allocator.h"
20
21int new_called = 0;
22
23void* operator new(std::size_t s) throw(std::bad_alloc)
24{
25    ++new_called;
26    return std::malloc(s);
27}
28
29void  operator delete(void* p) throw()
30{
31    --new_called;
32    std::free(p);
33}
34
35class A
36{
37    int data_[10];
38public:
39    static int count;
40
41    A()
42    {
43        ++count;
44        for (int i = 0; i < 10; ++i)
45            data_[i] = i;
46    }
47
48    A(const A&) {++count;}
49
50    ~A() {--count;}
51
52    int operator()(int i) const
53    {
54        for (int j = 0; j < 10; ++j)
55            i += data_[j];
56        return i;
57    }
58};
59
60int A::count = 0;
61
62int main()
63{
64#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
65    assert(new_called == 0);
66    {
67    std::function<int(int)> f = A();
68    assert(A::count == 1);
69    assert(new_called == 1);
70    assert(f.target<A>());
71    assert(f.target<int(*)(int)>() == 0);
72    std::function<int(int)> f2(std::allocator_arg, test_allocator<A>(), std::move(f));
73    assert(A::count == 1);
74    assert(new_called == 1);
75    assert(f2.target<A>());
76    assert(f2.target<int(*)(int)>() == 0);
77    assert(f.target<A>() == 0);
78    assert(f.target<int(*)(int)>() == 0);
79    }
80#endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES
81}
82