summaryrefslogtreecommitdiffstats
path: root/sandbox/sebastien/cpp/apr-2/kernel/lambda-test.cpp
blob: a72f01fb434a27c0c10f8fcf78a465ec9b23b57d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

/* $Rev$ $Date$ */

/**
 * Test C++0x lambda expressions.
 */

#include <assert.h>
#include "function.hpp"
#include "sstream.hpp"
#include "fstream.hpp"
#include "perf.hpp"

namespace tuscany {

#ifdef WANT_GCC45

const lambda<const int(const int)> inc(const int i) {
    return [=](const int x)->const int {
        return x + i;
    };
}

const int square(const int x) {
    return x * x;
}

int mapLambda(const lambda<const int(const int)> f, int v) {
    return f(v);
}

bool testLambda() {
    const lambda<const int(const int)> sq  = square;
    assert(sq(2) == 4);
    assert(mapLambda(square, 2) == 4);
    assert(mapLambda(sq, 2) == 4);
    assert(mapLambda([](const int x)->const int { return x * x; }, 2) == 4);

    const lambda<int(int)> incf = inc(10);
    assert(incf(1) == 11);
    assert(mapLambda(incf, 1) == 11);
    assert(mapLambda(inc(10), 1) == 11);

    lambda<const int(const int)> l;
    l = incf;
    assert(l(1) == 11);
    l = square;
    assert(l(2) == 4);
    return true;
}

const double fib_aux(const double n, const double a, const double b) {
    return n == 0.0? a : fib_aux(n - 1.0, b, a + b);
}

const bool fibMapPerf() {
    list<double> s = seq(0.0, 4999.0);
    list<double> r = map<double, double>([](const double n)->const double { return fib_aux(n, 0.0, 1.0); }, s);
    assert(5000 == length(r));
    return true;
}

bool testCppPerf() {
    cout << "Fibonacci map test " << (time([]()->const bool { return fibMapPerf(); }, 1, 1) / 5000) << " ms" << endl;
    return true;
}

#endif
}

int main() {
    tuscany::cout << "Testing..." << tuscany::endl;

#ifdef WANT_GCC45
    tuscany::testLambda();
    tuscany::testCppPerf();
#else
    tuscany::cout << "Skipped GCC 4.5 tests" << tuscany::endl;
#endif

    tuscany::cout << "OK" << tuscany::endl;

    return 0;
}