OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | |
2 // for details. All rights reserved. Use of this source code is governed by a | |
3 // BSD-style license that can be found in the LICENSE file. | |
4 | |
5 #include <math.h> | |
6 #include <limits> | |
7 | |
8 #include "platform/globals.h" | |
9 | |
10 // Taken from third_party/v8/src/platform-win32.cc | |
11 double modulo(double x, double y) { | |
12 // Workaround MS fmod bugs. ECMA-262 says: | |
Mads Ager (google)
2012/11/27 08:43:23
Please remove the reference to the JavaScript spec
aam-me
2012/11/28 00:45:34
Done.
| |
13 // dividend is finite and divisor is an infinity => result equals dividend | |
14 // dividend is a zero and divisor is nonzero finite => result equals dividend | |
15 if (!(_finite(x) && (!_finite(y) && !isnan(y))) && | |
16 !(x == 0 && (y != 0 && _finite(y)))) { | |
17 x = fmod(x, y); | |
18 } | |
19 return x; | |
20 } | |
21 | |
22 double round(double x) { | |
23 if (!_finite(x)) { | |
24 return x; | |
25 } | |
26 | |
27 double intpart; | |
28 double fractpart = modf(x, &intpart); | |
29 | |
30 if (fractpart >= 0.5) { | |
31 return (intpart + 1); | |
Mads Ager (google)
2012/11/27 08:43:23
I would remove the parenthesis here.
aam-me
2012/11/28 00:45:34
Done.
| |
32 } else if (fractpart > -0.5) { | |
33 return intpart; | |
34 } else { | |
35 return (intpart - 1); | |
Mads Ager (google)
2012/11/27 08:43:23
Ditto.
aam-me
2012/11/28 00:45:34
Done.
| |
36 } | |
37 } | |
38 | |
39 | |
40 // Bring MSVC atan2 behavior in line with standard. | |
Mads Ager (google)
2012/11/27 08:43:23
Expand comment to state that MSVC atan2 does not a
aam-me
2012/11/28 00:45:34
Done.
| |
41 double atan2_ieee(double x, double y) { | |
42 int cls_x = _fpclass(x); | |
43 int cls_y = _fpclass(y); | |
44 if (((cls_x & (_FPCLASS_PINF | _FPCLASS_NINF)) != 0) && | |
45 ((cls_y & (_FPCLASS_PINF | _FPCLASS_NINF)) != 0)) { | |
46 bool x_negative = (cls_x & _FPCLASS_NINF) != 0; | |
47 bool y_negative = (cls_y & _FPCLASS_NINF) != 0; | |
48 static double atans_at_infinities[2][2] = | |
49 { { atan2(1., 1.), atan2(1., -1.) }, | |
50 { atan2(-1., 1.), atan2(-1., -1.) } }; | |
51 return atans_at_infinities[x_negative][y_negative]; | |
Mads Ager (google)
2012/11/27 08:43:23
Please index with integers instead of booleans her
aam-me
2012/11/28 00:45:34
Done.
| |
52 } else { | |
53 return atan2(x, y); | |
54 } | |
55 } | |
OLD | NEW |