aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/buffer.js38
1 files changed, 14 insertions, 24 deletions
diff --git a/lib/buffer.js b/lib/buffer.js
index 66c345885a..b5d89625b2 100644
--- a/lib/buffer.js
+++ b/lib/buffer.js
@@ -195,33 +195,23 @@ Buffer.from = function from(value, encodingOrOffset, length) {
if (typeof value === 'string')
return fromString(value, encodingOrOffset);
- if (isAnyArrayBuffer(value))
- return fromArrayBuffer(value, encodingOrOffset, length);
+ if (typeof value === 'object' && value !== null) {
+ if (isAnyArrayBuffer(value))
+ return fromArrayBuffer(value, encodingOrOffset, length);
- if (value === null || value === undefined) {
- throw new ERR_INVALID_ARG_TYPE(
- 'first argument',
- ['string', 'Buffer', 'ArrayBuffer', 'Array', 'Array-like Object'],
- value
- );
- }
-
- if (typeof value === 'number') {
- throw new ERR_INVALID_ARG_TYPE('value', 'not number', value);
- }
+ const valueOf = value.valueOf && value.valueOf();
+ if (valueOf !== null && valueOf !== undefined && valueOf !== value)
+ return Buffer.from(valueOf, encodingOrOffset, length);
- const valueOf = value.valueOf && value.valueOf();
- if (valueOf !== null && valueOf !== undefined && valueOf !== value)
- return Buffer.from(valueOf, encodingOrOffset, length);
-
- const b = fromObject(value);
- if (b)
- return b;
+ const b = fromObject(value);
+ if (b)
+ return b;
- if (typeof value[Symbol.toPrimitive] === 'function') {
- return Buffer.from(value[Symbol.toPrimitive]('string'),
- encodingOrOffset,
- length);
+ if (typeof value[Symbol.toPrimitive] === 'function') {
+ return Buffer.from(value[Symbol.toPrimitive]('string'),
+ encodingOrOffset,
+ length);
+ }
}
throw new ERR_INVALID_ARG_TYPE(