boost/libs/safe_numerics/test/test_add_automatic.cpp
2021-10-05 21:37:46 +02:00

72 lines
2.1 KiB
C++

// Copyright (c) 2012 Robert Ramey
//
// 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)
#include <iostream>
#include <boost/safe_numerics/safe_integer.hpp>
#include <boost/safe_numerics/automatic.hpp>
#include "test_add_automatic_results.hpp"
template <class T>
using safe_t = boost::safe_numerics::safe<
T,
boost::safe_numerics::automatic
>;
#include "test_add.hpp"
#include <boost/mp11/list.hpp>
#include <boost/mp11/algorithm.hpp>
#include <boost/core/demangle.hpp>
using namespace boost::mp11;
template<typename L>
struct test {
static_assert(mp_is_list<L>(), "must be a list of integral constants");
bool m_error;
test(bool b = true) : m_error(b) {}
operator bool(){
return m_error;
}
template<typename T>
void operator()(const T &){
static_assert(mp_is_list<T>(), "must be a list of two integral constants");
constexpr size_t i1 = mp_first<T>(); // index of first argument
constexpr size_t i2 = mp_second<T>();// index of second argument
std::cout << i1 << ',' << i2 << ',';
using T1 = typename mp_at_c<L, i1>::value_type;
using T2 = typename mp_at_c<L, i2>::value_type;
m_error &= test_add(
mp_at_c<L, i1>()(), // value of first argument
mp_at_c<L, i2>()(), // value of second argument
boost::core::demangle(typeid(T1).name()).c_str(),
boost::core::demangle(typeid(T2).name()).c_str(),
test_addition_automatic_result[i1][i2]
);
}
};
#include "check_symmetry.hpp"
int main(){
static_assert(
check_symmetry(test_addition_automatic_result),
"sanity check on test matrix - should be symmetrical"
);
//TEST_EACH_VALUE_PAIR
test<test_values> rval(true);
using value_indices = mp_iota_c<mp_size<test_values>::value>;
mp_for_each<
mp_product<mp_list, value_indices, value_indices>
>(rval);
std::cout << (rval ? "success!" : "failure") << std::endl;
return ! rval ;
}