Content-Length: 282111 | pFad | https://github.com/webpack/webpack/commit/e76ad9e724410f10209caa2ba86875ca8cf5ed61

20 Merge pull request #16803 from ryanwilsonperkin/revert-16759-real-con… · webpack/webpack@e76ad9e · GitHub
Skip to content

Commit

Permalink
Merge pull request #16803 from ryanwilsonperkin/revert-16759-real-con…
Browse files Browse the repository at this point in the history
…tent-hash-regex-perf
  • Loading branch information
TheLarkInn authored Mar 10, 2023
2 parents c989143 + 52b1b0e commit e76ad9e
Showing 1 changed file with 14 additions and 44 deletions.
58 changes: 14 additions & 44 deletions lib/optimize/RealContentHashPlugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -178,43 +178,10 @@ class RealContentHashPlugin {
}
}
if (hashToAssets.size === 0) return;
const hashRegExps = Array.from(hashToAssets.keys(), quoteMeta).map(
hash => new RegExp(hash, "g")
const hashRegExp = new RegExp(
Array.from(hashToAssets.keys(), quoteMeta).join("|"),
"g"
);

/**
* @param {string} str string to be matched against all hashRegExps
* @returns {string[] | null} matches found
*/
const hashMatch = str => {
/** @type {string[]} */
const results = [];
for (const hashRegExp of hashRegExps) {
const matches = str.match(hashRegExp);
if (matches) {
matches.forEach(match => results.push(match));
}
}
if (results.length) {
return results;
} else {
return null;
}
};

/**
* @param {string} str string to be replaced with all hashRegExps
* @param {function(string): string} fn replacement function to use when a hash is found
* @returns {string} replaced content
*/
const hashReplace = (str, fn) => {
let result = str;
for (const hashRegExp of hashRegExps) {
result = result.replace(hashRegExp, fn);
}
return result;
};

await Promise.all(
assetsWithInfo.map(async asset => {
const { name, source, content, hashes } = asset;
Expand All @@ -231,7 +198,7 @@ class RealContentHashPlugin {
await cacheAnalyse.providePromise(name, etag, () => {
const referencedHashes = new Set();
let ownHashes = new Set();
const inContent = hashMatch(content);
const inContent = content.match(hashRegExp);
if (inContent) {
for (const hash of inContent) {
if (hashes.has(hash)) {
Expand Down Expand Up @@ -331,7 +298,7 @@ ${referencingAssets
identifier,
etag,
() => {
const newContent = hashReplace(asset.content, hash =>
const newContent = asset.content.replace(hashRegExp, hash =>
hashToNewHash.get(hash)
);
return new RawSource(newContent);
Expand All @@ -356,12 +323,15 @@ ${referencingAssets
identifier,
etag,
() => {
const newContent = hashReplace(asset.content, hash => {
if (asset.ownHashes.has(hash)) {
return "";
const newContent = asset.content.replace(
hashRegExp,
hash => {
if (asset.ownHashes.has(hash)) {
return "";
}
return hashToNewHash.get(hash);
}
return hashToNewHash.get(hash);
});
);
return new RawSource(newContent);
}
);
Expand Down Expand Up @@ -407,7 +377,7 @@ ${referencingAssets
await Promise.all(
assetsWithInfo.map(async asset => {
await computeNewContent(asset);
const newName = hashReplace(asset.name, hash =>
const newName = asset.name.replace(hashRegExp, hash =>
hashToNewHash.get(hash)
);

Expand Down

0 comments on commit e76ad9e

Please sign in to comment.








ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: https://github.com/webpack/webpack/commit/e76ad9e724410f10209caa2ba86875ca8cf5ed61

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy