From patchwork Fri Aug 6 08:59:48 2010 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: [v3] Improve ratio_less Date: Thu, 05 Aug 2010 22:59:48 -0000 From: Paolo Carlini X-Patchwork-Id: 61094 Message-Id: <4C5BCF04.3010601@oracle.com> To: Gcc Patch List Cc: libstdc++ Hi, committed to mainline. Paolo. //////////// 2010-08-06 Paolo Carlini * include/std/ratio (ratio_less): Improve, use ratio_divide to avoid more overflows. * testsuite/20_util/ratio/comparisons/comp1.cc: Extend. * testsuite/20_util/ratio/comparisons/comp2.cc: Likewise. Index: testsuite/20_util/ratio/comparisons/comp1.cc =================================================================== --- testsuite/20_util/ratio/comparisons/comp1.cc (revision 162897) +++ testsuite/20_util/ratio/comparisons/comp1.cc (working copy) @@ -1,7 +1,7 @@ // { dg-options "-std=gnu++0x" } // { dg-require-cstdint "" } -// Copyright (C) 2008, 2009 Free Software Foundation +// Copyright (C) 2008, 2009, 2010 Free Software Foundation // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the @@ -45,7 +45,12 @@ VERIFY( (std::ratio_less, std::ratio<1,4>>::value == 0) ); VERIFY( (std::ratio_less, std::ratio<-1,3>>::value == 0) ); - + + VERIFY( (std::ratio_less, std::ratio<-1,4>>::value == 1) ); + VERIFY( (std::ratio_less, std::ratio<0,3>>::value == 0) ); + VERIFY( (std::ratio_less, std::ratio<0,3>>::value == 0) ); + VERIFY( (std::ratio_less, std::ratio<-1,4>>::value == 0) ); + VERIFY( (std::ratio_less_equal, std::ratio<-1,3>>::value == 1) ); VERIFY( ( std::ratio_less_equal, Index: testsuite/20_util/ratio/comparisons/comp2.cc =================================================================== --- testsuite/20_util/ratio/comparisons/comp2.cc (revision 162897) +++ testsuite/20_util/ratio/comparisons/comp2.cc (working copy) @@ -1,7 +1,7 @@ // { dg-options "-std=gnu++0x" } // { dg-require-cstdint "" } -// Copyright (C) 2008, 2009 Free Software Foundation +// Copyright (C) 2008, 2009, 2010 Free Software Foundation // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the @@ -41,6 +41,13 @@ VERIFY( (std::ratio_less, std::ratio<-M, M - 1>>::value == 0) ); + + // No overflow + VERIFY( (std::ratio_less, + std::ratio>::value == 1) ); + + VERIFY( (std::ratio_less, + std::ratio<-M, M - 2>>::value == 0) ); } int main() Index: include/std/ratio =================================================================== --- include/std/ratio (revision 162897) +++ include/std/ratio (working copy) @@ -233,23 +233,30 @@ struct ratio_not_equal : integral_constant::value> { }; - + + template + struct __ratio_less_impl_1 + : integral_constant + { }; + + template::value + != __static_sign<_R2::num>::value)), + bool = (__static_sign<_R1::num>::value == -1 + && __static_sign<_R2::num>::value == -1)> + struct __ratio_less_impl + : __ratio_less_impl_1::type>::type + { }; + template - struct __ratio_less_simple_impl - : integral_constant::value - < __safe_multiply<_R2::num, _R1::den>::value)> + struct __ratio_less_impl<_R1, _R2, true, false> + : integral_constant { }; - // If the denominators are equal or the signs differ, we can just compare - // numerators, otherwise fallback to the simple cross-multiply method. template - struct __ratio_less_impl - : conditional<(_R1::den == _R2::den - || (__static_sign<_R1::num>::value - != __static_sign<_R2::num>::value)), - integral_constant, - __ratio_less_simple_impl<_R1, _R2>>::type + struct __ratio_less_impl<_R1, _R2, false, true> + : __ratio_less_impl_1::type>::type { }; /// ratio_less