mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
7b7e7bd185
If terminating the process with ctrl-c / SIGINT, prints a JS stacktrace leading up to the currently executing code. The feature would be enabled under option `--trace-sigint`. Conditions of no stacktrace on sigint: - has (an) active sigint listener(s); - main thread is idle (i.e. uv polling), a message instead of stacktrace would be printed. PR-URL: https://github.com/nodejs/node/pull/29207 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Christopher Hiller <boneskull@boneskull.com> Reviewed-By: Rich Trott <rtrott@gmail.com>
60 lines
1.3 KiB
JavaScript
60 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
const {
|
|
TraceSigintWatchdog
|
|
} = internalBinding('watchdog');
|
|
|
|
class SigintWatchdog extends TraceSigintWatchdog {
|
|
_started = false;
|
|
_effective = false;
|
|
_onNewListener = (eve) => {
|
|
if (eve === 'SIGINT' && this._effective) {
|
|
super.stop();
|
|
this._effective = false;
|
|
}
|
|
};
|
|
_onRemoveListener = (eve) => {
|
|
if (eve === 'SIGINT' && process.listenerCount('SIGINT') === 0 &&
|
|
!this._effective) {
|
|
super.start();
|
|
this._effective = true;
|
|
}
|
|
}
|
|
|
|
start() {
|
|
if (this._started) {
|
|
return;
|
|
}
|
|
this._started = true;
|
|
// Prepend sigint newListener to remove stop watchdog before signal wrap
|
|
// been activated. Also make sigint removeListener been ran after signal
|
|
// wrap been stopped.
|
|
process.prependListener('newListener', this._onNewListener);
|
|
process.addListener('removeListener', this._onRemoveListener);
|
|
|
|
if (process.listenerCount('SIGINT') === 0) {
|
|
super.start();
|
|
this._effective = true;
|
|
}
|
|
}
|
|
|
|
stop() {
|
|
if (!this._started) {
|
|
return;
|
|
}
|
|
this._started = false;
|
|
process.removeListener('newListener', this._onNewListener);
|
|
process.removeListener('removeListener', this._onRemoveListener);
|
|
|
|
if (this._effective) {
|
|
super.stop();
|
|
this._effective = false;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
module.exports = {
|
|
SigintWatchdog
|
|
};
|