File: range_based_for_support.h

package info (click to toggle)
onetbb 2022.3.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 19,440 kB
  • sloc: cpp: 129,228; ansic: 9,745; python: 808; xml: 183; objc: 176; makefile: 66; sh: 66; awk: 41; javascript: 37
file content (68 lines) | stat: -rw-r--r-- 2,347 bytes parent folder | download | duplicates (6)
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
/*
    Copyright (c) 2005-2021 Intel Corporation

    Licensed 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.
*/

#ifndef __TBB_test_common_range_based_for_support_H
#define __TBB_test_common_range_based_for_support_H

#include "config.h"

#include <utility>

namespace range_based_for_support_tests {

template <typename ValueType, typename Container, typename BinaryAccumulator, typename InitValueType>
inline InitValueType range_based_for_accumulate( const Container& c, BinaryAccumulator accumulator, InitValueType init ) {
    InitValueType range_based_for_accumulated = init;

    for (ValueType x : c) {
        range_based_for_accumulated = accumulator(range_based_for_accumulated, x);
    }
    return range_based_for_accumulated;
}

template <typename Container, typename BinaryAccumulator, typename InitValueType>
inline InitValueType range_based_for_accumulate( const Container& c, BinaryAccumulator accumulator, InitValueType init ) {
    return range_based_for_accumulate<typename Container::value_type>(c, accumulator, init);
}

template <typename IntegralType>
IntegralType gauss_summ_of_int_sequence( IntegralType sequence_length ) {
    return (sequence_length + 1) * sequence_length / 2;
}

struct UnifiedSummer {
    template <typename T>
    T operator()( const T& lhs, const T& rhs ) {
        return lhs + rhs;
    }

    template <typename T, typename U>
    U operator()( const U& lhs, const std::pair<T, U>& rhs ) {
        return lhs + rhs.second;
    }
}; // struct UnifiedSummer

struct pair_second_summer{
    template <typename first_type, typename second_type>
    second_type operator() (second_type const& lhs, std::pair<first_type, second_type> const& rhs) const
    {
        return lhs + rhs.second;
    }
};

} // namespace range_based_for_support_tests

#endif // __TBB_test_common_range_based_for_support_H