// Copyright (c) 2018 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 #include #include template constexpr bool test_checked_modulus( const T & v1, const T & v2, char expected_result ){ using namespace boost::safe_numerics; const T result = v1 % v2; switch(expected_result){ case '0': case '.': return ! result.exception(); case '-': return safe_numerics_error::negative_overflow_error == result.m_e; case '+': return safe_numerics_error::positive_overflow_error == result.m_e; case '!': return safe_numerics_error::range_error == result.m_e; } return false; } #include "test_checked_modulus.hpp" #include template struct test_signed_pair { static const std::size_t i = First(); static const std::size_t j = Second(); // note: is constexpr really required here? compilers disagree! constexpr static const bool value = test_checked_modulus( signed_values[i], signed_values[j], signed_modulus_results[i][j] ); }; template struct test_unsigned_pair { static const std::size_t i = First(); static const std::size_t j = Second(); // note: is constexpr really required here? compilers disagree! constexpr static const bool value = test_checked_modulus( unsigned_values[i], unsigned_values[j], unsigned_modulus_results[i][j] ); }; #include #include int main(){ using namespace boost::mp11; static_assert( mp_all_of< mp_product< test_signed_pair, signed_test_types, signed_value_indices, signed_value_indices >, mp_to_bool >(), "modulus for all signed values correct" ); static_assert( mp_all_of< mp_product< test_unsigned_pair, unsigned_test_types, unsigned_value_indices, unsigned_value_indices >, mp_to_bool >(), "modulus for all unsigned values correct" ); return 0; }