From 62b439ef8eaa7db9b85e32fa718f1c802f893b24 Mon Sep 17 00:00:00 2001 From: Dan Kaplun Date: Sun, 3 Jan 2016 18:32:58 -0500 Subject: [PATCH 1/2] strict mode fixes --- lib/program.js | 4 ++-- lib/tput.js | 20 ++++++++++---------- 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/lib/program.js b/lib/program.js index 0b1e56f..eeb060b 100644 --- a/lib/program.js +++ b/lib/program.js @@ -195,7 +195,7 @@ Program.prototype.setupDump = function() { return data.replace(/[\0\x80\x1b-\x1f\x7f\x01-\x1a]/g, function(ch) { switch (ch) { case '\0': - case '\200': + case '\x80': ch = '@'; break; case '\x1b': @@ -1911,7 +1911,7 @@ Program.prototype.getCursorColor = function(callback) { //Program.prototype.pad = Program.prototype.nul = function() { //if (this.has('pad')) return this.put.pad(); - return this._write('\200'); + return this._write('\x80'); }; Program.prototype.bel = diff --git a/lib/tput.js b/lib/tput.js index 4e4c1f0..37f512f 100644 --- a/lib/tput.js +++ b/lib/tput.js @@ -366,7 +366,7 @@ Tput.prototype.parseTerminfo = function(data, file) { o = 0; for (; i < l; i += 2) { v = Tput.numbers[o++]; - if (data[i + 1] === 0377 && data[i] === 0377) { + if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { info.numbers[v] = -1; } else { info.numbers[v] = (data[i + 1] << 8) | data[i]; @@ -379,7 +379,7 @@ Tput.prototype.parseTerminfo = function(data, file) { o = 0; for (; i < l; i += 2) { v = Tput.strings[o++]; - if (data[i + 1] === 0377 && data[i] === 0377) { + if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { info.strings[v] = -1; } else { info.strings[v] = (data[i + 1] << 8) | data[i]; @@ -533,7 +533,7 @@ Tput.prototype.parseExtended = function(data) { var _numbers = []; l = i + h.numCount * 2; for (; i < l; i += 2) { - if (data[i + 1] === 0377 && data[i] === 0377) { + if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { _numbers.push(-1); } else { _numbers.push((data[i + 1] << 8) | data[i]); @@ -544,7 +544,7 @@ Tput.prototype.parseExtended = function(data) { var _strings = []; l = i + h.strCount * 2; for (; i < l; i += 2) { - if (data[i + 1] === 0377 && data[i] === 0377) { + if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { _strings.push(-1); } else { _strings.push((data[i + 1] << 8) | data[i]); @@ -884,7 +884,7 @@ Tput.prototype._compile = function(info, key, str) { ch = ':'; break; case '0': - ch = '\200'; + ch = '\x80'; break; case 'a': ch = '\x07'; @@ -2098,10 +2098,10 @@ Tput.prototype.detectBrokenACS = function(info) { && process.env.TERMCAP && ~process.env.TERMCAP.indexOf('screen') && ~process.env.TERMCAP.indexOf('hhII00')) { - if (~info.strings.enter_alt_charset_mode.indexOf('\016') - || ~info.strings.enter_alt_charset_mode.indexOf('\017') - || ~info.strings.set_attributes.indexOf('\016') - || ~info.strings.set_attributes.indexOf('\017')) { + if (~info.strings.enter_alt_charset_mode.indexOf('\x0e') + || ~info.strings.enter_alt_charset_mode.indexOf('\x0f') + || ~info.strings.set_attributes.indexOf('\x0e') + || ~info.strings.set_attributes.indexOf('\x0f')) { return true; } } @@ -2280,7 +2280,7 @@ function sprintf(src) { break; case 'c': // char param = isFinite(param) - ? String.fromCharCode(param || 0200) + ? String.fromCharCode(param || parseInt('0200', 8)) : ''; break; } From ba1982d4a9243700bd4e6b27f169c3c96d084cd9 Mon Sep 17 00:00:00 2001 From: Dan Kaplun Date: Mon, 4 Jan 2016 02:50:49 -0500 Subject: [PATCH 2/2] Replace octal parseInt with hex literal --- lib/tput.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/tput.js b/lib/tput.js index 37f512f..0308649 100644 --- a/lib/tput.js +++ b/lib/tput.js @@ -366,7 +366,7 @@ Tput.prototype.parseTerminfo = function(data, file) { o = 0; for (; i < l; i += 2) { v = Tput.numbers[o++]; - if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { + if (data[i + 1] === 0xff && data[i] === 0xff) { info.numbers[v] = -1; } else { info.numbers[v] = (data[i + 1] << 8) | data[i]; @@ -379,7 +379,7 @@ Tput.prototype.parseTerminfo = function(data, file) { o = 0; for (; i < l; i += 2) { v = Tput.strings[o++]; - if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { + if (data[i + 1] === 0xff && data[i] === 0xff) { info.strings[v] = -1; } else { info.strings[v] = (data[i + 1] << 8) | data[i]; @@ -533,7 +533,7 @@ Tput.prototype.parseExtended = function(data) { var _numbers = []; l = i + h.numCount * 2; for (; i < l; i += 2) { - if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { + if (data[i + 1] === 0xff && data[i] === 0xff) { _numbers.push(-1); } else { _numbers.push((data[i + 1] << 8) | data[i]); @@ -544,7 +544,7 @@ Tput.prototype.parseExtended = function(data) { var _strings = []; l = i + h.strCount * 2; for (; i < l; i += 2) { - if (data[i + 1] === parseInt('0377', 8) && data[i] === parseInt('0377', 8)) { + if (data[i + 1] === 0xff && data[i] === 0xff) { _strings.push(-1); } else { _strings.push((data[i + 1] << 8) | data[i]); @@ -2280,7 +2280,7 @@ function sprintf(src) { break; case 'c': // char param = isFinite(param) - ? String.fromCharCode(param || parseInt('0200', 8)) + ? String.fromCharCode(param || 0x80) : ''; break; }