no-new-require.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /**
  2. * @fileoverview Rule to disallow use of new operator with the `require` function
  3. * @author Wil Moore III
  4. * @deprecated in ESLint v7.0.0
  5. */
  6. "use strict";
  7. //------------------------------------------------------------------------------
  8. // Rule Definition
  9. //------------------------------------------------------------------------------
  10. /** @type {import('../types').Rule.RuleModule} */
  11. module.exports = {
  12. meta: {
  13. deprecated: {
  14. message: "Node.js rules were moved out of ESLint core.",
  15. url: "https://eslint.org/docs/latest/use/migrating-to-7.0.0#deprecate-node-rules",
  16. deprecatedSince: "7.0.0",
  17. availableUntil: "11.0.0",
  18. replacedBy: [
  19. {
  20. message:
  21. "eslint-plugin-n now maintains deprecated Node.js-related rules.",
  22. plugin: {
  23. name: "eslint-plugin-n",
  24. url: "https://github.com/eslint-community/eslint-plugin-n",
  25. },
  26. rule: {
  27. name: "no-new-require",
  28. url: "https://github.com/eslint-community/eslint-plugin-n/tree/master/docs/rules/no-new-require.md",
  29. },
  30. },
  31. ],
  32. },
  33. type: "suggestion",
  34. docs: {
  35. description: "Disallow `new` operators with calls to `require`",
  36. recommended: false,
  37. url: "https://eslint.org/docs/latest/rules/no-new-require",
  38. },
  39. schema: [],
  40. messages: {
  41. noNewRequire: "Unexpected use of new with require.",
  42. },
  43. },
  44. create(context) {
  45. return {
  46. NewExpression(node) {
  47. if (
  48. node.callee.type === "Identifier" &&
  49. node.callee.name === "require"
  50. ) {
  51. context.report({
  52. node,
  53. messageId: "noNewRequire",
  54. });
  55. }
  56. },
  57. };
  58. },
  59. };