2012-02-28 03:09:35 +08:00
|
|
|
# util
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2012-03-03 07:14:03 +08:00
|
|
|
Stability: 5 - Locked
|
|
|
|
|
2010-10-28 20:18:16 +08:00
|
|
|
These functions are in the module `'util'`. Use `require('util')` to access
|
|
|
|
them.
|
|
|
|
|
|
|
|
|
2012-04-24 01:03:36 +08:00
|
|
|
## util.format(format, [...])
|
2011-08-05 22:37:16 +08:00
|
|
|
|
|
|
|
Returns a formatted string using the first argument as a `printf`-like format.
|
|
|
|
|
|
|
|
The first argument is a string that contains zero or more *placeholders*.
|
|
|
|
Each placeholder is replaced with the converted value from its corresponding
|
|
|
|
argument. Supported placeholders are:
|
|
|
|
|
|
|
|
* `%s` - String.
|
|
|
|
* `%d` - Number (both integer and float).
|
|
|
|
* `%j` - JSON.
|
|
|
|
* `%%` - single percent sign (`'%'`). This does not consume an argument.
|
|
|
|
|
2011-08-07 14:55:44 +08:00
|
|
|
If the placeholder does not have a corresponding argument, the placeholder is
|
|
|
|
not replaced.
|
2011-08-05 22:37:16 +08:00
|
|
|
|
2011-08-07 14:55:44 +08:00
|
|
|
util.format('%s:%s', 'foo'); // 'foo:%s'
|
2011-08-05 22:37:16 +08:00
|
|
|
|
|
|
|
If there are more arguments than placeholders, the extra arguments are
|
|
|
|
converted to strings with `util.inspect()` and these strings are concatenated,
|
|
|
|
delimited by a space.
|
|
|
|
|
|
|
|
util.format('%s:%s', 'foo', 'bar', 'baz'); // 'foo:bar baz'
|
|
|
|
|
|
|
|
If the first argument is not a format string then `util.format()` returns
|
|
|
|
a string that is the concatenation of all its arguments separated by spaces.
|
|
|
|
Each argument is converted to a string with `util.inspect()`.
|
|
|
|
|
|
|
|
util.format(1, 2, 3); // '1 2 3'
|
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.debug(string)
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
A synchronous output function. Will block the process and
|
|
|
|
output `string` immediately to `stderr`.
|
|
|
|
|
|
|
|
require('util').debug('message on stderr');
|
|
|
|
|
2012-04-24 01:03:36 +08:00
|
|
|
## util.error([...])
|
|
|
|
|
|
|
|
Same as `util.debug()` except this will output all arguments immediately to
|
|
|
|
`stderr`.
|
|
|
|
|
|
|
|
## util.puts([...])
|
|
|
|
|
|
|
|
A synchronous output function. Will block the process and output all arguments
|
|
|
|
to `stdout` with newlines after each argument.
|
|
|
|
|
|
|
|
## util.print([...])
|
|
|
|
|
|
|
|
A synchronous output function. Will block the process, cast each argument to a
|
|
|
|
string then output to `stdout`. Does not place newlines after each argument.
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.log(string)
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
Output with timestamp on `stdout`.
|
|
|
|
|
2011-06-03 19:19:06 +08:00
|
|
|
require('util').log('Timestamped message.');
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.inspect(object, [showHidden], [depth], [colors])
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
Return a string representation of `object`, which is useful for debugging.
|
|
|
|
|
|
|
|
If `showHidden` is `true`, then the object's non-enumerable properties will be
|
2011-12-27 16:43:58 +08:00
|
|
|
shown too. Defaults to `false`.
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
If `depth` is provided, it tells `inspect` how many times to recurse while
|
|
|
|
formatting the object. This is useful for inspecting large complicated objects.
|
|
|
|
|
|
|
|
The default is to only recurse twice. To make it recurse indefinitely, pass
|
|
|
|
in `null` for `depth`.
|
|
|
|
|
2011-12-08 09:15:40 +08:00
|
|
|
If `colors` is `true`, the output will be styled with ANSI color codes.
|
2011-12-27 16:43:58 +08:00
|
|
|
Defaults to `false`.
|
2011-12-08 09:15:40 +08:00
|
|
|
|
2010-10-28 20:18:16 +08:00
|
|
|
Example of inspecting all properties of the `util` object:
|
|
|
|
|
|
|
|
var util = require('util');
|
|
|
|
|
|
|
|
console.log(util.inspect(util, true, null));
|
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.isArray(object)
|
2011-10-27 02:10:23 +08:00
|
|
|
|
|
|
|
Returns `true` if the given "object" is an `Array`. `false` otherwise.
|
|
|
|
|
|
|
|
var util = require('util');
|
|
|
|
|
|
|
|
util.isArray([])
|
|
|
|
// true
|
|
|
|
util.isArray(new Array)
|
|
|
|
// true
|
|
|
|
util.isArray({})
|
|
|
|
// false
|
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.isRegExp(object)
|
2011-10-27 02:10:23 +08:00
|
|
|
|
|
|
|
Returns `true` if the given "object" is a `RegExp`. `false` otherwise.
|
|
|
|
|
|
|
|
var util = require('util');
|
|
|
|
|
|
|
|
util.isRegExp(/some regexp/)
|
|
|
|
// true
|
|
|
|
util.isRegExp(new RegExp('another regexp'))
|
|
|
|
// true
|
|
|
|
util.isRegExp({})
|
|
|
|
// false
|
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.isDate(object)
|
2011-10-27 02:10:23 +08:00
|
|
|
|
|
|
|
Returns `true` if the given "object" is a `Date`. `false` otherwise.
|
|
|
|
|
|
|
|
var util = require('util');
|
|
|
|
|
|
|
|
util.isDate(new Date())
|
|
|
|
// true
|
|
|
|
util.isDate(Date())
|
|
|
|
// false (without 'new' returns a String)
|
|
|
|
util.isDate({})
|
|
|
|
// false
|
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.isError(object)
|
2011-10-27 02:10:23 +08:00
|
|
|
|
|
|
|
Returns `true` if the given "object" is an `Error`. `false` otherwise.
|
|
|
|
|
|
|
|
var util = require('util');
|
|
|
|
|
|
|
|
util.isError(new Error())
|
|
|
|
// true
|
|
|
|
util.isError(new TypeError())
|
|
|
|
// true
|
|
|
|
util.isError({ name: 'Error', message: 'an error occurred' })
|
|
|
|
// false
|
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.pump(readableStream, writableStream, [callback])
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
Experimental
|
|
|
|
|
|
|
|
Read the data from `readableStream` and send it to the `writableStream`.
|
2011-01-12 02:18:46 +08:00
|
|
|
When `writableStream.write(data)` returns `false` `readableStream` will be
|
2010-10-28 20:18:16 +08:00
|
|
|
paused until the `drain` event occurs on the `writableStream`. `callback` gets
|
|
|
|
an error as its only argument and is called when `writableStream` is closed or
|
|
|
|
when an error occurs.
|
2010-11-21 13:28:19 +08:00
|
|
|
|
|
|
|
|
2012-02-28 03:09:35 +08:00
|
|
|
## util.inherits(constructor, superConstructor)
|
2010-11-21 13:28:19 +08:00
|
|
|
|
|
|
|
Inherit the prototype methods from one
|
|
|
|
[constructor](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Object/constructor)
|
|
|
|
into another. The prototype of `constructor` will be set to a new
|
|
|
|
object created from `superConstructor`.
|
|
|
|
|
|
|
|
As an additional convenience, `superConstructor` will be accessible
|
|
|
|
through the `constructor.super_` property.
|
|
|
|
|
|
|
|
var util = require("util");
|
|
|
|
var events = require("events");
|
|
|
|
|
|
|
|
function MyStream() {
|
|
|
|
events.EventEmitter.call(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
util.inherits(MyStream, events.EventEmitter);
|
|
|
|
|
|
|
|
MyStream.prototype.write = function(data) {
|
|
|
|
this.emit("data", data);
|
|
|
|
}
|
|
|
|
|
|
|
|
var stream = new MyStream();
|
|
|
|
|
|
|
|
console.log(stream instanceof events.EventEmitter); // true
|
|
|
|
console.log(MyStream.super_ === events.EventEmitter); // true
|
|
|
|
|
|
|
|
stream.on("data", function(data) {
|
|
|
|
console.log('Received data: "' + data + '"');
|
|
|
|
})
|
|
|
|
stream.write("It works!"); // Received data: "It works!"
|