38 lines
976 B
JavaScript
38 lines
976 B
JavaScript
|
'use strict';
|
||
|
// The Node team wants to deprecate `process.bind(...)`.
|
||
|
// https://github.com/nodejs/node/pull/2768
|
||
|
//
|
||
|
// However, we need the 'uv' binding for errname support.
|
||
|
// This is a defensive wrapper around it so `execa` will not fail entirely if it stops working someday.
|
||
|
//
|
||
|
// If this ever stops working. See: https://github.com/sindresorhus/execa/issues/31#issuecomment-215939939 for another possible solution.
|
||
|
let uv;
|
||
|
|
||
|
try {
|
||
|
uv = process.binding('uv');
|
||
|
|
||
|
if (typeof uv.errname !== 'function') {
|
||
|
throw new TypeError('uv.errname is not a function');
|
||
|
}
|
||
|
} catch (err) {
|
||
|
console.error('execa/lib/errname: unable to establish process.binding(\'uv\')', err);
|
||
|
uv = null;
|
||
|
}
|
||
|
|
||
|
function errname(uv, code) {
|
||
|
if (uv) {
|
||
|
return uv.errname(code);
|
||
|
}
|
||
|
|
||
|
if (!(code < 0)) {
|
||
|
throw new Error('err >= 0');
|
||
|
}
|
||
|
|
||
|
return `Unknown system error ${code}`;
|
||
|
}
|
||
|
|
||
|
module.exports = code => errname(uv, code);
|
||
|
|
||
|
// Used for testing the fallback behavior
|
||
|
module.exports.__test__ = errname;
|