blob: e000e7ab4b8b4d7f7ac918f138f44ff3cde62071 [file] [log] [blame]
 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file // for details. All rights reserved. Use of this source code is governed by a // BSD-style license that can be found in the LICENSE file. /// @assertion double operator %(num other) /// @description Checks that if the divisor is infinite and the dividend is a /// finite positive double the result equals the dividend, the result is infinity /// if dividend is negative. /// @author pagolubev import "../../../Utils/expect.dart"; final inf = double.infinity; final List values = const [ 4.9406564584124654e-324, // min 2.2250738585072014e-308, // min normal 1.7976931348623157e308, // max normal .7, .9999999999999999, 1.0, 1.0000000000000002, 10.0, 99.0, 99.99999999999999, 100.0, 100.00000000000001, 101.0, 6031769.5, 4.2949672959999995E9, 4.294967296E9, 4.294967296000001E9, 4.5035996273704955E15, 4.503599627370496E15, 4.503599627370497E15, 3.273390607896142E150, ]; main() { Expect.equals(0.0, 0.0 % inf); Expect.equals(0.0, 0.0 % (-inf)); Expect.equals(0.0, (-0.0) % inf); Expect.equals(0.0, (-0.0) % (-inf)); values.forEach((double d) { Expect.equals(d, d % inf); Expect.equals(double.infinity, (-d) % inf); Expect.equals(d, d % (-inf)); Expect.equals(double.infinity, (-d) % (-inf)); }); }