File: dummy_storage.hpp

package info (click to toggle)
boost1.74 1.74.0-9
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 464,084 kB
  • sloc: cpp: 3,338,324; xml: 131,293; python: 33,088; ansic: 14,336; asm: 4,034; sh: 3,351; makefile: 1,193; perl: 1,036; yacc: 478; php: 212; ruby: 102; lisp: 24; sql: 13; csh: 6
file content (58 lines) | stat: -rw-r--r-- 1,577 bytes parent folder | download | duplicates (10)
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
// Copyright 2020 Hans Dembinski
//
// Distributed under the Boost Software License, Version 1.0.
// (See accompanying file LICENSE_1_0.txt
// or copy at http://www.boost.org/LICENSE_1_0.txt)

#ifndef BOOST_HISTOGRAM_TEST_DUMMY_STORAGE_HPP
#define BOOST_HISTOGRAM_TEST_DUMMY_STORAGE_HPP

#include <algorithm>
#include <array>
#include <boost/histogram/detail/detect.hpp>
#include <ostream>
#include <type_traits>

template <class ValueType, bool Scaleable>
struct dummy_storage : std::array<ValueType, 10> {
  using base_t = std::array<ValueType, 10>;

  static constexpr bool has_threading_support = false;
  static constexpr bool scaleable =
      Scaleable && boost::histogram::detail::has_operator_rmul<ValueType, double>::value;

  std::size_t size_ = 0;

  std::size_t size() const { return size_; }

  void reset(std::size_t n) {
    assert(n < this->max_size());
    size_ = n;
  }

  auto end() { return this->begin() + size(); }
  auto end() const { return this->begin() + size(); }

  bool operator==(const dummy_storage& o) const {
    return std::equal(this->begin(), end(), o.begin(), o.end());
  }

  template <class S = dummy_storage>
  std::enable_if_t<S::scaleable, dummy_storage&> operator*=(double) {
    // do nothing, so it works with unscalable value types for testing purposes
    return *this;
  }
};

struct unscaleable {
  int value = 0;
  void operator++() { ++value; }
  bool operator==(const int& o) const { return value == o; }
};

inline std::ostream& operator<<(std::ostream& os, const unscaleable& x) {
  os << x.value;
  return os;
}

#endif