-
-
Notifications
You must be signed in to change notification settings - Fork 893
Description
The new version of Firefox (52) broke the parseInt() behavior on the test if (parseInt(ws + '08') !== 8 || parseInt(ws + '0x16') !== 22)
(line 1956) because of wrong whitespace characters ; returning NaN for both instead of 8 and 22.
Thus parseInt() is redefined by your shim. However, the case parseInt()
(empty parameter, or undefined, or null) throws an exception while using trim(string)
(line 1962) instead of returning NaN (as default behavior) - trim() should never be called with undefined or null as parameter.
This fixes the issue : if (str === undefined || str === null) str = "";
(to add before line 1962) ; Do not attempt to return NaN directly instead as it has bad side effects on some libraries (such as PerfectScrollbar) - I don't know why but it does.
Full example:
// ES-5 15.1.2.2
/* eslint-disable radix */
if (parseInt(ws + '08') !== 8 || parseInt(ws + '0x16') !== 22) {
/* eslint-enable radix */
/* global parseInt: true */
parseInt = (function (origParseInt) {
var hexRegex = /^[\-+]?0[xX]/;
return function parseInt(str, radix) {
if (str === undefined || str === null) str = "" ; // Fix here
var string = trim(str);
var defaultedRadix = $Number(radix) || (hexRegex.test(string) ? 16 : 10);
return origParseInt(string, defaultedRadix);
};
}(parseInt));
}
The redefined function parseFloat() should have the same fix too (before line 1974).
I've reported the parseInt() issue to Bugzilla, and here is the answer : https://bugzilla.mozilla.org/show_bug.cgi?id=1347869
To sum up, \u180E
is no longer supported in Unicode 9 as a whitespace. This particular test should be removed in the ws
variable (line 1903).