131 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			131 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| //  (C) Copyright Gennadiy Rozental 2001.
 | |
| //  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 <boost/test/tools/detail/fwd.hpp>
 | |
| #include <boost/test/tools/detail/indirections.hpp>
 | |
| 
 | |
| #include <boost/test/tools/fpc_tolerance.hpp>
 | |
| #include <boost/test/tools/floating_point_comparison.hpp>
 | |
| 
 | |
| #include <boost/test/detail/suppress_warnings.hpp>
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| namespace boost {
 | |
| namespace test_tools {
 | |
| namespace tt_detail {
 | |
| 
 | |
| // ************************************************************************** //
 | |
| // **************           fpc tolerance manipulator          ************** //
 | |
| // ************************************************************************** //
 | |
| 
 | |
| template<typename FPT>
 | |
| struct tolerance_manip {
 | |
|     explicit tolerance_manip( FPT const & tol ) : m_value( tol ) {}
 | |
| 
 | |
|     FPT m_value;
 | |
| };
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| struct tolerance_manip_delay {};
 | |
| 
 | |
| template<typename FPT>
 | |
| inline tolerance_manip<FPT>
 | |
| operator%( FPT v, tolerance_manip_delay const& )
 | |
| {
 | |
|     BOOST_STATIC_ASSERT_MSG( (fpc::tolerance_based<FPT>::value), 
 | |
|                              "tolerance should be specified using a floating points type" );
 | |
| 
 | |
|     return tolerance_manip<FPT>( FPT(v / 100) );
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| template<typename E, typename FPT>
 | |
| inline assertion_result
 | |
| operator<<(assertion_evaluate_t<E> const& ae, tolerance_manip<FPT> const& tol)
 | |
| {
 | |
|     local_fpc_tolerance<FPT> lt( tol.m_value );
 | |
| 
 | |
|     return ae.m_e.evaluate();
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| template<typename FPT>
 | |
| inline int
 | |
| operator<<( unit_test::lazy_ostream const&, tolerance_manip<FPT> const& )   { return 0; }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| template<typename FPT>
 | |
| inline check_type
 | |
| operator<<( assertion_type const& /*at*/, tolerance_manip<FPT> 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<typename FPT>
 | |
| inline tt_detail::tolerance_manip<FPT>
 | |
| tolerance( FPT v )
 | |
| {
 | |
|     BOOST_STATIC_ASSERT_MSG( (fpc::tolerance_based<FPT>::value), 
 | |
|                              "tolerance only for floating points" );
 | |
| 
 | |
|     return tt_detail::tolerance_manip<FPT>( v );
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| //! @overload tolerance( FPT v )
 | |
| template<typename FPT>
 | |
| inline tt_detail::tolerance_manip<FPT>
 | |
| tolerance( fpc::percent_tolerance_t<FPT> v )
 | |
| {
 | |
|     BOOST_STATIC_ASSERT_MSG( (fpc::tolerance_based<FPT>::value), 
 | |
|                              "tolerance only for floating points" );
 | |
| 
 | |
|     return tt_detail::tolerance_manip<FPT>( static_cast<FPT>(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 <boost/test/detail/enable_warnings.hpp>
 | |
| 
 | |
| #endif // BOOST_TEST_TOOLS_DETAIL_TOLERANCE_MANIP_HPP_012705GER
 | 
