From db74c1f584d517f1a5d1cbb781955a0cf149e42a Mon Sep 17 00:00:00 2001 From: nickreid Date: Fri, 25 Oct 2024 18:29:54 -0700 Subject: [PATCH] Only allocate a child-map for SimpleTopLevelIndex.Nodes that represent packages. This should eliminate over half of all child-maps. PiperOrigin-RevId: 689975386 --- .../binder/lookup/SimpleTopLevelIndex.java | 24 ++++++++++++------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/java/com/google/turbine/binder/lookup/SimpleTopLevelIndex.java b/java/com/google/turbine/binder/lookup/SimpleTopLevelIndex.java index 882e7148..48ccfb75 100644 --- a/java/com/google/turbine/binder/lookup/SimpleTopLevelIndex.java +++ b/java/com/google/turbine/binder/lookup/SimpleTopLevelIndex.java @@ -16,12 +16,13 @@ package com.google.turbine.binder.lookup; +import static com.google.common.base.Preconditions.checkNotNull; + import com.google.common.base.Supplier; import com.google.common.base.Suppliers; import com.google.common.collect.ImmutableList; import com.google.turbine.binder.sym.ClassSymbol; import java.util.HashMap; -import java.util.Map; import java.util.Objects; import org.jspecify.annotations.Nullable; @@ -37,17 +38,20 @@ public class SimpleTopLevelIndex implements TopLevelIndex { public static class Node { public @Nullable Node lookup(String bit) { - return children.get(bit); + return (children == null) ? null : children.get(bit); } private final @Nullable ClassSymbol sym; - - // TODO(cushon): the set of children is typically going to be small, consider optimizing this - // to use a denser representation where appropriate. - private final Map children = new HashMap<>(); + private final @Nullable HashMap children; Node(@Nullable ClassSymbol sym) { - this.sym = sym; + if (sym == null) { + this.sym = null; + this.children = new HashMap<>(); + } else { + this.sym = sym; + this.children = null; + } } /** @@ -57,6 +61,7 @@ public static class Node { * @return {@code null} if an existing symbol with the same name has already been inserted. */ private @Nullable Node insert(String name, @Nullable ClassSymbol sym) { + checkNotNull(children, "Cannot insert child into a class node '%s'", this.sym); Node child = children.get(name); if (child != null) { if (child.sym != null) { @@ -105,7 +110,6 @@ public void insert(ClassSymbol sym) { if (curr == null || !Objects.equals(curr.sym, sym)) { return; } - return; } } @@ -191,6 +195,10 @@ public PackageIndex(Node node) { new Supplier>() { @Override public ImmutableList get() { + if (node.children == null) { + return ImmutableList.of(); + } + ImmutableList.Builder result = ImmutableList.builder(); for (Node child : node.children.values()) { if (child.sym != null) {