HookWebpackError.js 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /*
  2. MIT License http://www.opensource.org/licenses/mit-license.php
  3. Author Sean Larkin @thelarkinn
  4. */
  5. "use strict";
  6. const WebpackError = require("./WebpackError");
  7. /** @typedef {import("./Module")} Module */
  8. /**
  9. * @template T
  10. * @callback Callback
  11. * @param {Error | null} err
  12. * @param {T=} stats
  13. * @returns {void}
  14. */
  15. class HookWebpackError extends WebpackError {
  16. /**
  17. * Creates an instance of HookWebpackError.
  18. * @param {Error} error inner error
  19. * @param {string} hook name of hook
  20. */
  21. constructor(error, hook) {
  22. super(error.message);
  23. this.name = "HookWebpackError";
  24. this.hook = hook;
  25. this.error = error;
  26. this.hideStack = true;
  27. this.details = `caused by plugins in ${hook}\n${error.stack}`;
  28. this.stack += `\n-- inner error --\n${error.stack}`;
  29. }
  30. }
  31. module.exports = HookWebpackError;
  32. /**
  33. * @param {Error} error an error
  34. * @param {string} hook name of the hook
  35. * @returns {WebpackError} a webpack error
  36. */
  37. const makeWebpackError = (error, hook) => {
  38. if (error instanceof WebpackError) return error;
  39. return new HookWebpackError(error, hook);
  40. };
  41. module.exports.makeWebpackError = makeWebpackError;
  42. /**
  43. * @template T
  44. * @param {function(WebpackError | null, T=): void} callback webpack error callback
  45. * @param {string} hook name of hook
  46. * @returns {Callback<T>} generic callback
  47. */
  48. const makeWebpackErrorCallback = (callback, hook) => (err, result) => {
  49. if (err) {
  50. if (err instanceof WebpackError) {
  51. callback(err);
  52. return;
  53. }
  54. callback(new HookWebpackError(err, hook));
  55. return;
  56. }
  57. callback(null, result);
  58. };
  59. module.exports.makeWebpackErrorCallback = makeWebpackErrorCallback;
  60. /**
  61. * @template T
  62. * @param {function(): T} fn function which will be wrapping in try catch
  63. * @param {string} hook name of hook
  64. * @returns {T} the result
  65. */
  66. const tryRunOrWebpackError = (fn, hook) => {
  67. let r;
  68. try {
  69. r = fn();
  70. } catch (err) {
  71. if (err instanceof WebpackError) {
  72. throw err;
  73. }
  74. throw new HookWebpackError(/** @type {Error} */ (err), hook);
  75. }
  76. return r;
  77. };
  78. module.exports.tryRunOrWebpackError = tryRunOrWebpackError;