From 406650e4dcb52284e389f5d2b7f6b1d960d2fcf5 Mon Sep 17 00:00:00 2001 From: Gora Kong <15333808+gorakong@users.noreply.github.com> Date: Thu, 2 Nov 2023 19:57:11 -0700 Subject: [PATCH 1/2] Reduce redundancy in the RequestGraph's file nodes (#9360) * remove value objects in file nodes * remove opaque type * restore opaque type --- packages/core/core/src/RequestTracker.js | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/packages/core/core/src/RequestTracker.js b/packages/core/core/src/RequestTracker.js index 4da53bbb4e4..ed3b0e4e62b 100644 --- a/packages/core/core/src/RequestTracker.js +++ b/packages/core/core/src/RequestTracker.js @@ -13,7 +13,6 @@ import type { import type { ParcelOptions, RequestInvalidation, - InternalFile, InternalFileCreateInvalidation, InternalGlob, } from './types'; @@ -84,7 +83,7 @@ type SerializedRequestGraph = {| invalidateOnBuildNodeIds: Set, |}; -type FileNode = {|id: ContentKey, +type: 'file', value: InternalFile|}; +type FileNode = {|id: ContentKey, +type: 'file'|}; type GlobNode = {|id: ContentKey, +type: 'glob', value: InternalGlob|}; type FileNameNode = {| id: ContentKey, @@ -167,7 +166,6 @@ export type StaticRunOpts = {| const nodeFromFilePath = (filePath: ProjectPath): RequestGraphNode => ({ id: fromProjectPathRelative(filePath), type: 'file', - value: {filePath}, }); const nodeFromGlob = (glob: InternalGlob): RequestGraphNode => ({ @@ -609,7 +607,7 @@ export class RequestGraph extends ContentGraph< let node = nullthrows(this.getNode(nodeId)); switch (node.type) { case 'file': - return {type: 'file', filePath: node.value.filePath}; + return {type: 'file', filePath: toProjectPathUnsafe(node.id)}; case 'env': return {type: 'env', key: node.value.key}; case 'option': @@ -675,7 +673,7 @@ export class RequestGraph extends ContentGraph< requestGraphEdgeTypes.invalidated_by_create_above, ) && isDirectoryInside( - fromProjectPathRelative(matchNode.value.filePath), + fromProjectPathRelative(toProjectPathUnsafe(matchNode.id)), dirname, ) ) { From eeb3ba3de6e4fe037cd4f5d73939fa6867faa1f4 Mon Sep 17 00:00:00 2001 From: Niklas Mischkulnig <4586894+mischnic@users.noreply.github.com> Date: Sat, 4 Nov 2023 05:06:03 +0100 Subject: [PATCH 2/2] Don't crash if WebExt has no content_scripts (#9341) --- .../transformers/webextension/src/WebExtensionTransformer.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/transformers/webextension/src/WebExtensionTransformer.js b/packages/transformers/webextension/src/WebExtensionTransformer.js index ac12fbb8669..51cbe6a0ef7 100644 --- a/packages/transformers/webextension/src/WebExtensionTransformer.js +++ b/packages/transformers/webextension/src/WebExtensionTransformer.js @@ -343,7 +343,7 @@ async function collectDependencies( program.permissions.push('scripting'); } const hostPerms = [ - ...new Set(program.content_scripts.flatMap(sc => sc.matches)), + ...new Set(program.content_scripts?.flatMap(sc => sc.matches)), ]; if (isMV2) program.permissions = program.permissions.concat(hostPerms); else {