File: VisitTree.hpp

package info (click to toggle)
reflect-cpp 0.18.0%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 12,524 kB
  • sloc: cpp: 44,484; python: 131; makefile: 30; sh: 3
file content (29 lines) | stat: -rw-r--r-- 908 bytes parent folder | download | duplicates (2)
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
#ifndef RFL_INTERNAL_VISITTREE_HPP_
#define RFL_INTERNAL_VISITTREE_HPP_

namespace rfl {
namespace internal {

struct VisitTree {
    /// Evaluates a visitor pattern using a tree-like structure.
    template <int _begin, int _end, class Visitor, class... Args>
    static inline auto visit(const auto& _v, const int _i,
                             const Args&... _args) {
        static_assert(_end > _begin, "_end needs to be greater than _begin.");
        if constexpr (_end - _begin == 1) {
            return _v.template visit<_begin>(_args...);
        } else {
            constexpr int middle = (_begin + _end) / 2;
            if (_i < middle) {
                return visit<_begin, middle, Visitor>(_v, _i, _args...);
            } else {
                return visit<middle, _end, Visitor>(_v, _i, _args...);
            }
        }
    }
};

}  // namespace internal
}  // namespace rfl

#endif