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 |