// (C) Copyright Gennadiy Rozental 2011-2014. // 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) // See http://www.boost.org/libs/test for the library home page. // //! @file //! @brief Floating point comparison tolerance manipulators //! //! This file defines several manipulators for floating point comparison. These //! manipulators are intended to be used with BOOST_TEST. // *************************************************************************** #ifndef BOOST_TEST_TOOLS_DETAIL_TOLERANCE_MANIP_HPP_012705GER #define BOOST_TEST_TOOLS_DETAIL_TOLERANCE_MANIP_HPP_012705GER // Boost Test #include #include #include #include #include //____________________________________________________________________________// namespace boost { namespace test_tools { namespace tt_detail { // ************************************************************************** // // ************** fpc tolerance manipulator ************** // // ************************************************************************** // template struct tolerance_manip { explicit tolerance_manip( FPT const & tol ) : m_value( tol ) {} FPT m_value; }; //____________________________________________________________________________// struct tolerance_manip_delay {}; template inline tolerance_manip operator%( FPT v, tolerance_manip_delay const& ) { BOOST_STATIC_ASSERT_MSG( (fpc::tolerance_based::value), "tolerance only for floating points" ); return tolerance_manip( FPT(v / 100) ); } //____________________________________________________________________________// template inline assertion_result operator<<(assertion_evaluate_t const& ae, tolerance_manip const& tol) { local_fpc_tolerance lt( tol.m_value ); return ae.m_e.evaluate(); } //____________________________________________________________________________// template inline int operator<<( unit_test::lazy_ostream const&, tolerance_manip const& ) { return 0; } //____________________________________________________________________________// template inline check_type operator<<( assertion_type const& /*at*/, tolerance_manip const& ) { return CHECK_BUILT_ASSERTION; } //____________________________________________________________________________// } // namespace tt_detail /*! Tolerance manipulator * * These functions return a manipulator that can be used in conjunction with BOOST_TEST * in order to specify the tolerance with which floating point comparisons are made. */ template inline tt_detail::tolerance_manip tolerance( FPT v ) { BOOST_STATIC_ASSERT_MSG( (fpc::tolerance_based::value), "tolerance only for floating points" ); return tt_detail::tolerance_manip( v ); } //____________________________________________________________________________// //! @overload tolerance( FPT v ) template inline tt_detail::tolerance_manip tolerance( fpc::percent_tolerance_t v ) { BOOST_STATIC_ASSERT_MSG( (fpc::tolerance_based::value), "tolerance only for floating points" ); return tt_detail::tolerance_manip( static_cast(v.m_value / 100) ); } //____________________________________________________________________________// //! @overload tolerance( FPT v ) inline tt_detail::tolerance_manip_delay tolerance() { return tt_detail::tolerance_manip_delay(); } //____________________________________________________________________________// } // namespace test_tools } // namespace boost #include #endif // BOOST_TEST_TOOLS_DETAIL_TOLERANCE_MANIP_HPP_012705GER