mirror of
https://github.com/nodejs/node.git
synced 2025-05-04 22:16:16 +00:00

Reduce the number of emitExperimentalWarning() call sites by making process.report emit a warning on access instead of each individual report function. PR-URL: https://github.com/nodejs/node/pull/26414 Reviewed-By: Richard Lau <riclau@uk.ibm.com> Reviewed-By: Wyatt Preul <wpreul@gmail.com>
111 lines
2.8 KiB
JavaScript
111 lines
2.8 KiB
JavaScript
'use strict';
|
|
const { convertToValidSignal } = require('internal/util');
|
|
const {
|
|
ERR_INVALID_ARG_TYPE,
|
|
ERR_SYNTHETIC
|
|
} = require('internal/errors').codes;
|
|
const { validateString } = require('internal/validators');
|
|
const nr = internalBinding('report');
|
|
const report = {
|
|
triggerReport(file, err) {
|
|
if (typeof file === 'object' && file !== null) {
|
|
err = file;
|
|
file = undefined;
|
|
} else if (file !== undefined && typeof file !== 'string') {
|
|
throw new ERR_INVALID_ARG_TYPE('file', 'String', file);
|
|
} else if (err === undefined) {
|
|
err = new ERR_SYNTHETIC();
|
|
} else if (err === null || typeof err !== 'object') {
|
|
throw new ERR_INVALID_ARG_TYPE('err', 'Object', err);
|
|
}
|
|
|
|
return nr.triggerReport('JavaScript API', 'API', file, err.stack);
|
|
},
|
|
getReport(err) {
|
|
if (err === undefined)
|
|
err = new ERR_SYNTHETIC();
|
|
else if (err === null || typeof err !== 'object')
|
|
throw new ERR_INVALID_ARG_TYPE('err', 'Object', err);
|
|
|
|
return nr.getReport(err.stack);
|
|
},
|
|
get directory() {
|
|
return nr.getDirectory();
|
|
},
|
|
set directory(dir) {
|
|
validateString(dir, 'directory');
|
|
return nr.setDirectory(dir);
|
|
},
|
|
get filename() {
|
|
return nr.getFilename();
|
|
},
|
|
set filename(name) {
|
|
validateString(name, 'filename');
|
|
return nr.setFilename(name);
|
|
},
|
|
get signal() {
|
|
return nr.getSignal();
|
|
},
|
|
set signal(sig) {
|
|
validateString(sig, 'signal');
|
|
convertToValidSignal(sig); // Validate that the signal is recognized.
|
|
removeSignalHandler();
|
|
addSignalHandler(sig);
|
|
return nr.setSignal(sig);
|
|
},
|
|
get reportOnFatalError() {
|
|
return nr.shouldReportOnFatalError();
|
|
},
|
|
set reportOnFatalError(trigger) {
|
|
if (typeof trigger !== 'boolean')
|
|
throw new ERR_INVALID_ARG_TYPE('trigger', 'boolean', trigger);
|
|
|
|
return nr.setReportOnFatalError(trigger);
|
|
},
|
|
get reportOnSignal() {
|
|
return nr.shouldReportOnSignal();
|
|
},
|
|
set reportOnSignal(trigger) {
|
|
if (typeof trigger !== 'boolean')
|
|
throw new ERR_INVALID_ARG_TYPE('trigger', 'boolean', trigger);
|
|
|
|
nr.setReportOnSignal(trigger);
|
|
removeSignalHandler();
|
|
addSignalHandler();
|
|
},
|
|
get reportOnUncaughtException() {
|
|
return nr.shouldReportOnUncaughtException();
|
|
},
|
|
set reportOnUncaughtException(trigger) {
|
|
if (typeof trigger !== 'boolean')
|
|
throw new ERR_INVALID_ARG_TYPE('trigger', 'boolean', trigger);
|
|
|
|
return nr.setReportOnUncaughtException(trigger);
|
|
}
|
|
};
|
|
|
|
function addSignalHandler(sig) {
|
|
if (nr.shouldReportOnSignal()) {
|
|
if (typeof sig !== 'string')
|
|
sig = nr.getSignal();
|
|
|
|
process.on(sig, signalHandler);
|
|
}
|
|
}
|
|
|
|
function removeSignalHandler() {
|
|
const sig = nr.getSignal();
|
|
|
|
if (sig)
|
|
process.removeListener(sig, signalHandler);
|
|
}
|
|
|
|
function signalHandler(sig) {
|
|
nr.triggerReport(sig, 'Signal', null, '');
|
|
}
|
|
|
|
module.exports = {
|
|
addSignalHandler,
|
|
report
|
|
};
|