// 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 // std::int8, ... #include #include #include // note: T should be of tyme checked_result for some integer type R template constexpr bool test_checked_divide( 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_divide.hpp" 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_divide( signed_values[i], signed_values[j], signed_division_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_divide( unsigned_values[i], unsigned_values[j], unsigned_division_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 >(), "all values for all signed types correctly divided" ); static_assert( mp_all_of< mp_product< test_unsigned_pair, unsigned_test_types, unsigned_value_indices, unsigned_value_indices >, mp_to_bool >(), "all values for all unsigned types correctly divided" ); return 0; }