| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 181 // Note: here we rely on dependent reads being ordered. This is true | 181 // Note: here we rely on dependent reads being ordered. This is true |
| 182 // on all architectures we currently support. | 182 // on all architectures we currently support. |
| 183 return (*modulo_function)(x, y); | 183 return (*modulo_function)(x, y); |
| 184 } | 184 } |
| 185 #else // Win32 | 185 #else // Win32 |
| 186 | 186 |
| 187 double modulo(double x, double y) { | 187 double modulo(double x, double y) { |
| 188 // Workaround MS fmod bugs. ECMA-262 says: | 188 // Workaround MS fmod bugs. ECMA-262 says: |
| 189 // dividend is finite and divisor is an infinity => result equals dividend | 189 // dividend is finite and divisor is an infinity => result equals dividend |
| 190 // dividend is a zero and divisor is nonzero finite => result equals dividend | 190 // dividend is a zero and divisor is nonzero finite => result equals dividend |
| 191 if (!(isfinite(x) && (!isfinite(y) && !isnan(y))) && | 191 if (!(std::isfinite(x) && (!std::isfinite(y) && !std::isnan(y))) && |
| 192 !(x == 0 && (y != 0 && isfinite(y)))) { | 192 !(x == 0 && (y != 0 && std::isfinite(y)))) { |
| 193 x = fmod(x, y); | 193 x = fmod(x, y); |
| 194 } | 194 } |
| 195 return x; | 195 return x; |
| 196 } | 196 } |
| 197 | 197 |
| 198 #endif // _WIN64 | 198 #endif // _WIN64 |
| 199 | 199 |
| 200 | 200 |
| 201 #define UNARY_MATH_FUNCTION(name, generator) \ | 201 #define UNARY_MATH_FUNCTION(name, generator) \ |
| 202 static UnaryMathFunction fast_##name##_function = NULL; \ | 202 static UnaryMathFunction fast_##name##_function = NULL; \ |
| (...skipping 1783 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1986 limit_mutex = CreateMutex(); | 1986 limit_mutex = CreateMutex(); |
| 1987 } | 1987 } |
| 1988 | 1988 |
| 1989 | 1989 |
| 1990 void OS::TearDown() { | 1990 void OS::TearDown() { |
| 1991 delete limit_mutex; | 1991 delete limit_mutex; |
| 1992 } | 1992 } |
| 1993 | 1993 |
| 1994 | 1994 |
| 1995 } } // namespace v8::internal | 1995 } } // namespace v8::internal |
| OLD | NEW |