LogInfoPlugin.js 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /*
  2. MIT License http://www.opensource.org/licenses/mit-license.php
  3. Author Tobias Koppers @sokra
  4. */
  5. "use strict";
  6. /** @typedef {import("./Resolver")} Resolver */
  7. /** @typedef {import("./Resolver").ResolveStepHook} ResolveStepHook */
  8. module.exports = class LogInfoPlugin {
  9. /**
  10. * @param {string | ResolveStepHook} source source
  11. */
  12. constructor(source) {
  13. this.source = source;
  14. }
  15. /**
  16. * @param {Resolver} resolver the resolver
  17. * @returns {void}
  18. */
  19. apply(resolver) {
  20. const source = this.source;
  21. resolver
  22. .getHook(this.source)
  23. .tapAsync("LogInfoPlugin", (request, resolveContext, callback) => {
  24. if (!resolveContext.log) return callback();
  25. const log = resolveContext.log;
  26. const prefix = "[" + source + "] ";
  27. if (request.path)
  28. log(prefix + "Resolving in directory: " + request.path);
  29. if (request.request)
  30. log(prefix + "Resolving request: " + request.request);
  31. if (request.module) log(prefix + "Request is an module request.");
  32. if (request.directory) log(prefix + "Request is a directory request.");
  33. if (request.query)
  34. log(prefix + "Resolving request query: " + request.query);
  35. if (request.fragment)
  36. log(prefix + "Resolving request fragment: " + request.fragment);
  37. if (request.descriptionFilePath)
  38. log(
  39. prefix + "Has description data from " + request.descriptionFilePath
  40. );
  41. if (request.relativePath)
  42. log(
  43. prefix +
  44. "Relative path from description file is: " +
  45. request.relativePath
  46. );
  47. callback();
  48. });
  49. }
  50. };