postProcessPattern.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = postProcessPattern;
  6. var _path = _interopRequireDefault(require("path"));
  7. var _os = _interopRequireDefault(require("os"));
  8. var _crypto = _interopRequireDefault(require("crypto"));
  9. var _loaderUtils = _interopRequireDefault(require("loader-utils"));
  10. var _cacache = _interopRequireDefault(require("cacache"));
  11. var _serializeJavascript = _interopRequireDefault(require("serialize-javascript"));
  12. var _findCacheDir = _interopRequireDefault(require("find-cache-dir"));
  13. var _normalizePath = _interopRequireDefault(require("normalize-path"));
  14. var _package = require("../package.json");
  15. var _promisify = require("./utils/promisify");
  16. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  17. /* eslint-disable no-param-reassign */
  18. function postProcessPattern(globalRef, pattern, file) {
  19. const {
  20. logger,
  21. compilation,
  22. fileDependencies,
  23. written,
  24. inputFileSystem,
  25. copyUnmodified
  26. } = globalRef;
  27. logger.debug(`getting stats for '${file.absoluteFrom}' to write to assets`);
  28. const getStats = pattern.stats ? Promise.resolve().then(() => pattern.stats) : (0, _promisify.stat)(inputFileSystem, file.absoluteFrom);
  29. return getStats.then(stats => {
  30. // We don't write empty directories
  31. if (stats.isDirectory()) {
  32. logger.debug(`skipping '${file.absoluteFrom}' because it is empty directory`);
  33. return Promise.resolve();
  34. } // If this came from a glob, add it to the file watchlist
  35. if (pattern.fromType === 'glob') {
  36. fileDependencies.add(file.absoluteFrom);
  37. }
  38. logger.debug(`reading '${file.absoluteFrom}' to write to assets`);
  39. return (0, _promisify.readFile)(inputFileSystem, file.absoluteFrom).then(content => {
  40. if (pattern.transform) {
  41. logger.info(`transforming content for '${file.absoluteFrom}'`); // eslint-disable-next-line no-shadow
  42. const transform = (content, absoluteFrom) => pattern.transform(content, absoluteFrom);
  43. if (pattern.cache) {
  44. if (!globalRef.cacheDir) {
  45. globalRef.cacheDir = (0, _findCacheDir.default)({
  46. name: 'copy-webpack-plugin'
  47. }) || _os.default.tmpdir();
  48. }
  49. const cacheKey = pattern.cache.key ? pattern.cache.key : (0, _serializeJavascript.default)({
  50. name: _package.name,
  51. version: _package.version,
  52. pattern,
  53. hash: _crypto.default.createHash('md4').update(content).digest('hex')
  54. });
  55. return _cacache.default.get(globalRef.cacheDir, cacheKey).then(result => {
  56. logger.debug(`getting cached transformation for '${file.absoluteFrom}'`);
  57. return result.data;
  58. }, () => Promise.resolve().then(() => transform(content, file.absoluteFrom)) // eslint-disable-next-line no-shadow
  59. .then(content => {
  60. logger.debug(`caching transformation for '${file.absoluteFrom}'`);
  61. return _cacache.default.put(globalRef.cacheDir, cacheKey, content).then(() => content);
  62. }));
  63. }
  64. content = transform(content, file.absoluteFrom);
  65. }
  66. return content;
  67. }).then(content => {
  68. if (pattern.toType === 'template') {
  69. logger.info(`interpolating template '${file.webpackTo}' for '${file.relativeFrom}'`); // If it doesn't have an extension, remove it from the pattern
  70. // ie. [name].[ext] or [name][ext] both become [name]
  71. if (!_path.default.extname(file.relativeFrom)) {
  72. file.webpackTo = file.webpackTo.replace(/\.?\[ext\]/g, '');
  73. }
  74. file.webpackTo = _loaderUtils.default.interpolateName({
  75. resourcePath: file.absoluteFrom
  76. }, file.webpackTo, {
  77. content,
  78. regExp: file.webpackToRegExp,
  79. context: pattern.context
  80. }); // Bug in `loader-utils`, package convert `\\` to `/`, need fix in loader-utils
  81. file.webpackTo = _path.default.normalize(file.webpackTo);
  82. }
  83. return content;
  84. }).then(content => {
  85. if (pattern.transformPath) {
  86. logger.info(`transforming path '${file.webpackTo}' for '${file.absoluteFrom}'`);
  87. return Promise.resolve().then(() => pattern.transformPath(file.webpackTo, file.absoluteFrom)).then(newPath => {
  88. file.webpackTo = newPath;
  89. return content;
  90. });
  91. }
  92. return content;
  93. }).then(content => {
  94. const hash = _loaderUtils.default.getHashDigest(content);
  95. const targetPath = (0, _normalizePath.default)(file.webpackTo);
  96. const targetAbsolutePath = (0, _normalizePath.default)(file.absoluteFrom);
  97. if (!copyUnmodified && written[targetPath] && written[targetPath][targetAbsolutePath] && written[targetPath][targetAbsolutePath] === hash) {
  98. logger.info(`skipping '${file.webpackTo}', because content hasn't changed`);
  99. return;
  100. }
  101. logger.debug(`adding '${file.webpackTo}' for tracking content changes`);
  102. if (!written[targetPath]) {
  103. written[targetPath] = {};
  104. }
  105. written[targetPath][targetAbsolutePath] = hash;
  106. if (compilation.assets[targetPath] && !file.force) {
  107. logger.info(`skipping '${file.webpackTo}', because it already exists`);
  108. return;
  109. }
  110. logger.info(`writing '${file.webpackTo}' to compilation assets from '${file.absoluteFrom}'`);
  111. compilation.assets[targetPath] = {
  112. size() {
  113. return stats.size;
  114. },
  115. source() {
  116. return content;
  117. }
  118. };
  119. });
  120. });
  121. }