console: `console.dir()` bypasses inspect() methods

Use the `customInspect: false` option of `util.inspect()` to bypass any custom
inspect() function on the object being logged.

Closes #2717.
This commit is contained in:
Nathan Rajlich 2013-01-29 18:44:29 -08:00
Родитель 43c1830e0a
Коммит da8b0eefde
3 изменённых файлов: 15 добавлений и 3 удалений

Просмотреть файл

@ -33,7 +33,8 @@ Same as `console.error`.
## console.dir(obj) ## console.dir(obj)
Uses `util.inspect` on `obj` and prints resulting string to stdout. Uses `util.inspect` on `obj` and prints resulting string to stdout. This function
bypasses any custom `inspect()` function on `obj`.
## console.time(label) ## console.time(label)

Просмотреть файл

@ -66,7 +66,7 @@ Console.prototype.error = Console.prototype.warn;
Console.prototype.dir = function(object) { Console.prototype.dir = function(object) {
this._stdout.write(util.inspect(object) + '\n'); this._stdout.write(util.inspect(object, { customInspect: false }) + '\n');
}; };

Просмотреть файл

@ -31,27 +31,38 @@ assert.ok(process.stderr.writable);
assert.equal('number', typeof process.stdout.fd); assert.equal('number', typeof process.stdout.fd);
assert.equal('number', typeof process.stderr.fd); assert.equal('number', typeof process.stderr.fd);
// an Object with a custom .inspect() function
var custom_inspect = { foo: 'bar', inspect: function () { return 'inspect'; } };
var stdout_write = global.process.stdout.write; var stdout_write = global.process.stdout.write;
var strings = []; var strings = [];
global.process.stdout.write = function(string) { global.process.stdout.write = function(string) {
strings.push(string); strings.push(string);
}; };
console._stderr = process.stdout;
// test console.log()
console.log('foo'); console.log('foo');
console.log('foo', 'bar'); console.log('foo', 'bar');
console.log('%s %s', 'foo', 'bar', 'hop'); console.log('%s %s', 'foo', 'bar', 'hop');
console.log({slashes: '\\\\'}); console.log({slashes: '\\\\'});
console.log(custom_inspect);
console._stderr = process.stdout; // test console.dir()
console.dir(custom_inspect);
// test console.trace()
console.trace('This is a %j %d', { formatted: 'trace' }, 10, 'foo'); console.trace('This is a %j %d', { formatted: 'trace' }, 10, 'foo');
global.process.stdout.write = stdout_write; global.process.stdout.write = stdout_write;
assert.equal('foo\n', strings.shift()); assert.equal('foo\n', strings.shift());
assert.equal('foo bar\n', strings.shift()); assert.equal('foo bar\n', strings.shift());
assert.equal('foo bar hop\n', strings.shift()); assert.equal('foo bar hop\n', strings.shift());
assert.equal("{ slashes: '\\\\\\\\' }\n", strings.shift()); assert.equal("{ slashes: '\\\\\\\\' }\n", strings.shift());
assert.equal('inspect\n', strings.shift());
assert.equal("{ foo: 'bar', inspect: [Function] }\n", strings.shift());
assert.equal('Trace: This is a {"formatted":"trace"} 10 foo', assert.equal('Trace: This is a {"formatted":"trace"} 10 foo',
strings.shift().split('\n').shift()); strings.shift().split('\n').shift());