LogInfoPlugin.js 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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;
  21. resolver
  22. .getHook(this.source)
  23. .tapAsync("LogInfoPlugin", (request, resolveContext, callback) => {
  24. if (!resolveContext.log) return callback();
  25. const { log } = resolveContext;
  26. const prefix = `[${source}] `;
  27. if (request.path) {
  28. log(`${prefix}Resolving in directory: ${request.path}`);
  29. }
  30. if (request.request) {
  31. log(`${prefix}Resolving request: ${request.request}`);
  32. }
  33. if (request.module) log(`${prefix}Request is an module request.`);
  34. if (request.directory) log(`${prefix}Request is a directory request.`);
  35. if (request.query) {
  36. log(`${prefix}Resolving request query: ${request.query}`);
  37. }
  38. if (request.fragment) {
  39. log(`${prefix}Resolving request fragment: ${request.fragment}`);
  40. }
  41. if (request.descriptionFilePath) {
  42. log(
  43. `${prefix}Has description data from ${request.descriptionFilePath}`,
  44. );
  45. }
  46. if (request.relativePath) {
  47. log(
  48. `${prefix}Relative path from description file is: ${request.relativePath}`,
  49. );
  50. }
  51. callback();
  52. });
  53. }
  54. };