From 134225241ebec1f19b3718ca93ab805fd85ca146 Mon Sep 17 00:00:00 2001 From: James Petty Date: Thu, 16 May 2024 13:37:38 -0400 Subject: [PATCH] Allow reusing Scope temp variables --- src/main/java/io/airlift/bytecode/Scope.java | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/src/main/java/io/airlift/bytecode/Scope.java b/src/main/java/io/airlift/bytecode/Scope.java index 9b66e00..951eaf7 100644 --- a/src/main/java/io/airlift/bytecode/Scope.java +++ b/src/main/java/io/airlift/bytecode/Scope.java @@ -18,6 +18,9 @@ import org.objectweb.asm.Type; import java.util.ArrayList; +import java.util.Deque; +import java.util.HashMap; +import java.util.LinkedList; import java.util.List; import java.util.Map; import java.util.Optional; @@ -33,6 +36,7 @@ public class Scope private final Map variables = new TreeMap<>(); private final Map tempVariables = new TreeMap<>(); private final List allVariables = new ArrayList<>(); + private final Map> releasedTempVariables = new HashMap<>(); private final Variable thisVariable; @@ -73,6 +77,22 @@ public Variable createTempVariable(Class type) return variable; } + public Variable getOrCreateTempVariable(Class type) + { + Deque typeVariables = releasedTempVariables.get(type(type)); + if (typeVariables == null || typeVariables.isEmpty()) { + return createTempVariable(type); + } + return typeVariables.pop(); + } + + public void releaseTempVariableForReuse(Variable tempVariable) + { + requireNonNull(tempVariable, "tempVariable is null"); + checkArgument(tempVariable == tempVariables.get(tempVariable.getName()), "invalid tempVariable release: %s", tempVariable); + releasedTempVariables.computeIfAbsent(tempVariable.getType(), ignored -> new LinkedList<>()).push(tempVariable); + } + public Variable getTempVariable(String name) { Variable variable = tempVariables.get(name);