Pull white space checks into function

Clean up code by pulling white space checks into a seperate helper
function
This commit is contained in:
griffpatch 2017-02-10 08:02:11 +00:00
parent 338b2f3458
commit ad5bc1afbd

View file

@ -90,6 +90,15 @@ Cast.toRgbColorObject = function (value) {
return color; return color;
}; };
/**
* Determine if a Scratch argument is a white space string (or null / empty).
* @param {*} val value to check.
* @return {boolean} True if the argument is all white spaces or null / empty.
*/
Cast.isWhiteSpace = function (val) {
return val === null || typeof val === 'string' && val.trim().length === 0;
};
/** /**
* Compare two values, using Scratch cast, case-insensitive string compare, etc. * Compare two values, using Scratch cast, case-insensitive string compare, etc.
* In Scratch 2.0, this is captured by `interp.compare.` * In Scratch 2.0, this is captured by `interp.compare.`
@ -100,10 +109,9 @@ Cast.toRgbColorObject = function (value) {
Cast.compare = function (v1, v2) { Cast.compare = function (v1, v2) {
var n1 = Number(v1); var n1 = Number(v1);
var n2 = Number(v2); var n2 = Number(v2);
if (n1 === 0 && (v1 == null || typeof v1 === 'string' && v1.trim().length === 0)) { if (n1 === 0 && Cast.isWhiteSpace(v1)) {
n1 = NaN; n1 = NaN;
} } else if (n2 === 0 && Cast.isWhiteSpace(v2)) {
if (n2 === 0 && (v2 == null || typeof v2 === 'string' && v2.trim().length === 0)) {
n2 = NaN; n2 = NaN;
} }
if (isNaN(n1) || isNaN(n2)) { if (isNaN(n1) || isNaN(n2)) {