From f185d003a024c0ae390a9174118f9b8be4755f60 Mon Sep 17 00:00:00 2001 From: Lydia Garms Date: Thu, 21 Nov 2024 13:36:17 +0000 Subject: [PATCH] fix: error in variable declaration when mappings of structs are used with multiple mapping keys --- src/transformers/visitors/toOrchestrationVisitor.ts | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/transformers/visitors/toOrchestrationVisitor.ts b/src/transformers/visitors/toOrchestrationVisitor.ts index 7847e670..ac7bd9cf 100644 --- a/src/transformers/visitors/toOrchestrationVisitor.ts +++ b/src/transformers/visitors/toOrchestrationVisitor.ts @@ -1511,13 +1511,11 @@ const visitor = { } i++; }); - // check whether this should be a VariableDeclaration const firstEdit = (firstInstanceOfNewName && indicator.interactsWithSecret) || (!indicator.isStruct && indicator.modifyingPaths[0]?.node.id === lhs?.id && indicator.isSecret && indicator.isWhole) || - (indicator.isStruct && indicator instanceof MappingKey && indicator.container.modifyingPaths[0]?.node.id === lhs?.id && indicator.isSecret && indicator.isWhole); - + (indicator.isStruct && indicator instanceof MappingKey && indicator.modifyingPaths[0]?.node.id === lhs?.id && indicator.isSecret && indicator.isWhole); // We should only replace the _first_ assignment to this node. Let's look at the scope's modifiedBindings for any prior modifications to this binding: // if its secret and this is the first assigment, we add a vardec if ( @@ -1531,7 +1529,6 @@ const visitor = { ) accessed = true; }); - // we still need to initialise accessed states if they were accessed _before_ this modification const accessedBeforeModification = indicator.isAccessed && indicator.accessedPaths[0].node.id < lhs.id && !indicator.accessedPaths[0].isModification();