deprecation-warnings.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /**
  2. * @fileoverview Provide the function that emits deprecation warnings.
  3. * @author Toru Nagashima <http://github.com/mysticatea>
  4. */
  5. "use strict";
  6. //------------------------------------------------------------------------------
  7. // Requirements
  8. //------------------------------------------------------------------------------
  9. const path = require("path");
  10. //------------------------------------------------------------------------------
  11. // Private
  12. //------------------------------------------------------------------------------
  13. // Defitions for deprecation warnings.
  14. const deprecationWarningMessages = {
  15. ESLINT_LEGACY_ECMAFEATURES:
  16. "The 'ecmaFeatures' config file property is deprecated and has no effect.",
  17. ESLINT_PERSONAL_CONFIG_LOAD:
  18. "'~/.eslintrc.*' config files have been deprecated. " +
  19. "Please use a config file per project or the '--config' option.",
  20. ESLINT_PERSONAL_CONFIG_SUPPRESS:
  21. "'~/.eslintrc.*' config files have been deprecated. " +
  22. "Please remove it or add 'root:true' to the config files in your " +
  23. "projects in order to avoid loading '~/.eslintrc.*' accidentally."
  24. };
  25. const sourceFileErrorCache = new Set();
  26. /**
  27. * Emits a deprecation warning containing a given filepath. A new deprecation warning is emitted
  28. * for each unique file path, but repeated invocations with the same file path have no effect.
  29. * No warnings are emitted if the `--no-deprecation` or `--no-warnings` Node runtime flags are active.
  30. * @param {string} source The name of the configuration source to report the warning for.
  31. * @param {string} errorCode The warning message to show.
  32. * @returns {void}
  33. */
  34. function emitDeprecationWarning(source, errorCode) {
  35. const cacheKey = JSON.stringify({ source, errorCode });
  36. if (sourceFileErrorCache.has(cacheKey)) {
  37. return;
  38. }
  39. sourceFileErrorCache.add(cacheKey);
  40. const rel = path.relative(process.cwd(), source);
  41. const message = deprecationWarningMessages[errorCode];
  42. process.emitWarning(
  43. `${message} (found in "${rel}")`,
  44. "DeprecationWarning",
  45. errorCode
  46. );
  47. }
  48. //------------------------------------------------------------------------------
  49. // Public Interface
  50. //------------------------------------------------------------------------------
  51. module.exports = {
  52. emitDeprecationWarning
  53. };