
To be followed by tests and `npm run build`, obviously! Reviewed-on: #1 Co-authored-by: Jack Jackson <scubbojj@gmail.com> Co-committed-by: Jack Jackson <scubbojj@gmail.com>
64 lines
2.0 KiB
JavaScript
64 lines
2.0 KiB
JavaScript
/**
|
|
* @fileoverview Disallow the use of process.exit()
|
|
* @author Nicholas C. Zakas
|
|
* @deprecated in ESLint v7.0.0
|
|
*/
|
|
"use strict";
|
|
|
|
//------------------------------------------------------------------------------
|
|
// Rule Definition
|
|
//------------------------------------------------------------------------------
|
|
|
|
/** @type {import('../shared/types').Rule} */
|
|
module.exports = {
|
|
meta: {
|
|
deprecated: {
|
|
message: "Node.js rules were moved out of ESLint core.",
|
|
url: "https://eslint.org/docs/latest/use/migrating-to-7.0.0#deprecate-node-rules",
|
|
deprecatedSince: "7.0.0",
|
|
availableUntil: null,
|
|
replacedBy: [
|
|
{
|
|
message: "eslint-plugin-n now maintains deprecated Node.js-related rules.",
|
|
plugin: {
|
|
name: "eslint-plugin-n",
|
|
url: "https://github.com/eslint-community/eslint-plugin-n"
|
|
},
|
|
rule: {
|
|
name: "no-process-exit",
|
|
url: "https://github.com/eslint-community/eslint-plugin-n/tree/master/docs/rules/no-process-exit.md"
|
|
}
|
|
}
|
|
]
|
|
},
|
|
|
|
type: "suggestion",
|
|
|
|
docs: {
|
|
description: "Disallow the use of `process.exit()`",
|
|
recommended: false,
|
|
url: "https://eslint.org/docs/latest/rules/no-process-exit"
|
|
},
|
|
|
|
schema: [],
|
|
|
|
messages: {
|
|
noProcessExit: "Don't use process.exit(); throw an error instead."
|
|
}
|
|
},
|
|
|
|
create(context) {
|
|
|
|
//--------------------------------------------------------------------------
|
|
// Public
|
|
//--------------------------------------------------------------------------
|
|
|
|
return {
|
|
"CallExpression > MemberExpression.callee[object.name = 'process'][property.name = 'exit']"(node) {
|
|
context.report({ node: node.parent, messageId: "noProcessExit" });
|
|
}
|
|
};
|
|
|
|
}
|
|
};
|