// 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 #include #include #include // note: T should be of tyme checked_result for some integer type R template bool test_checked_and( T v1, T v2, char expected_result ){ using namespace boost::safe_numerics; const T result = v1 & v2; std::cout << v1 << " & " << v2 << " -> " << result << std::endl; switch(expected_result){ case '.': if(result.exception()){ std::cout << "erroneously detected error in and operation " << std::endl; v1 & v2; return false; } return true; case '-': if(safe_numerics_error::negative_overflow_error == result.m_e) return true; break; case '+': if(safe_numerics_error::positive_overflow_error == result.m_e) return true; break; case '!': if(safe_numerics_error::range_error == result.m_e) return true; break; } std::cout << "failed to detect error in and operation " << std::hex << result << "(" << std::dec << result << ")" << " != "<< v1 << " & " << v2 << std::endl; v1 & v2; return false; } #include "test_checked_and.hpp" template struct test_signed_pair { bool operator()() const { std::size_t i = First(); std::size_t j = Second(); std::cout << std::dec << i << ',' << j << ',' << "testing " << boost::core::demangle(typeid(T).name()) << ' '; return test_checked_and( signed_values[i], signed_values[j], signed_and_results[i][j] ); }; }; template struct test_unsigned_pair { bool operator()() const { std::size_t i = First(); std::size_t j = Second(); std::cout << std::dec << i << ',' << j << ',' << "testing " << boost::core::demangle(typeid(T).name()) << ' '; return test_checked_and( unsigned_values[i], unsigned_values[j], unsigned_and_results[i][j] ); }; }; #include "check_symmetry.hpp" #include int main(){ static_assert( check_symmetry(signed_and_results), "sanity check on test matrix - should be symmetrical" ); static_assert( check_symmetry(unsigned_and_results), "sanity check on test matrix - should be symmetrical" ); using namespace boost::mp11; bool rval = true; std::cout << "*** testing signed values\n"; mp_for_each< mp_product< test_signed_pair, signed_test_types, signed_value_indices, signed_value_indices > >([&](auto I){ rval &= I(); }); std::cout << "*** testing unsigned values\n"; mp_for_each< mp_product< test_unsigned_pair, unsigned_test_types, unsigned_value_indices, unsigned_value_indices > >([&](auto I){ rval &= I(); }); std::cout << (rval ? "success!" : "failure") << std::endl; return rval ? 0 : 1; }