Skip to content

Commit

Permalink
Fixed: throws non-intuitive error on color.red(null) but not on color…
Browse files Browse the repository at this point in the history
…s.red(undefined) (#261)
  • Loading branch information
jweinsteincbt authored and DABH committed Sep 22, 2019
1 parent aa012aa commit 5d9eb90
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 4 deletions.
4 changes: 2 additions & 2 deletions lib/colors.js
Original file line number Diff line number Diff line change
Expand Up @@ -105,8 +105,8 @@ function applyStyle() {
var args = Array.prototype.slice.call(arguments);

var str = args.map(function(arg) {
// Use weak equality check so we can colorize null in safe mode
if (arg != undefined && arg.constructor === String) {
// Use weak equality check so we can colorize null/undefined in safe mode
if (arg != null && arg.constructor === String) {
return arg;
} else {
return util.inspect(arg);
Expand Down
2 changes: 1 addition & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "colors",
"description": "get colors in your node.js console",
"version": "1.3.3",
"version": "1.3.4",
"author": "Marak Squires",
"contributors": [
{
Expand Down
7 changes: 7 additions & 0 deletions tests/safe-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,3 +66,10 @@ colors.setTheme({custom: ['red', 'italic', 'inverse']});
assert.equal(colors.custom(s),
'\x1b[7m' + '\x1b[3m' + '\x1b[31m' + s +
'\x1b[39m' + '\x1b[23m' + '\x1b[27m' );

// should not throw error on null or undefined values
var undef;
assert.equal(colors.yellow(undef), '\x1b[33mundefined\x1b[39m');

// was failing:
assert.equal(colors.red(null), '\x1b[31mnull\x1b[39m');

0 comments on commit 5d9eb90

Please sign in to comment.