aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar michajlo <michajlo@google.com>2017-08-04 21:35:53 +0200
committerGravatar Jakob Buchgraber <buchgr@google.com>2017-08-07 11:22:18 +0200
commita33485ad91c9954e793c4580ca9f1e54e91a67f0 (patch)
tree4f3ba6e1da699a94eb970a926fd7db0985419f89
parent77e8b03f9a5ca45344cd86b74d076461e43aabb3 (diff)
Bypass unnecessary ArrayLists in SkylarkNestedSet constructor
No need for the intermediate collection/objects when we can go direct to ImmutableList, which has a good chance of doing something more efficient anyway... PiperOrigin-RevId: 164295659
-rw-r--r--src/main/java/com/google/devtools/build/lib/syntax/SkylarkNestedSet.java23
1 files changed, 11 insertions, 12 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/syntax/SkylarkNestedSet.java b/src/main/java/com/google/devtools/build/lib/syntax/SkylarkNestedSet.java
index c38fe89b6a..dc143c31be 100644
--- a/src/main/java/com/google/devtools/build/lib/syntax/SkylarkNestedSet.java
+++ b/src/main/java/com/google/devtools/build/lib/syntax/SkylarkNestedSet.java
@@ -24,7 +24,6 @@ import com.google.devtools.build.lib.skylarkinterface.SkylarkModuleCategory;
import com.google.devtools.build.lib.skylarkinterface.SkylarkPrinter;
import com.google.devtools.build.lib.skylarkinterface.SkylarkValue;
import com.google.devtools.build.lib.util.Preconditions;
-import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import javax.annotation.Nullable;
@@ -120,14 +119,14 @@ public final class SkylarkNestedSet implements SkylarkValue, SkylarkQueryable {
private SkylarkNestedSet(Order order, SkylarkType contentType, Object item, Location loc,
@Nullable SkylarkNestedSet left) throws EvalException {
- ArrayList<Object> items = new ArrayList<>();
- ArrayList<NestedSet> transitiveItems = new ArrayList<>();
+ ImmutableList.Builder<Object> itemsBuilder = ImmutableList.builder();
+ ImmutableList.Builder<NestedSet> transitiveItemsBuilder = ImmutableList.builder();
if (left != null) {
if (left.items == null) { // SkylarkSet created from native NestedSet
- transitiveItems.add(left.set);
+ transitiveItemsBuilder.add(left.set);
} else { // Preserving the left-to-right addition order.
- items.addAll(left.items);
- transitiveItems.addAll(left.transitiveItems);
+ itemsBuilder.addAll(left.items);
+ transitiveItemsBuilder.addAll(left.transitiveItems);
}
}
// Adding the item
@@ -135,14 +134,14 @@ public final class SkylarkNestedSet implements SkylarkValue, SkylarkQueryable {
SkylarkNestedSet nestedSet = (SkylarkNestedSet) item;
if (!nestedSet.isEmpty()) {
contentType = getTypeAfterInsert(contentType, nestedSet.contentType, loc);
- transitiveItems.add(nestedSet.set);
+ transitiveItemsBuilder.add(nestedSet.set);
}
} else if (item instanceof SkylarkList) {
// TODO(bazel-team): we should check ImmutableList here but it screws up genrule at line 43
for (Object object : (SkylarkList) item) {
contentType = getTypeAfterInsert(contentType, SkylarkType.of(object.getClass()), loc);
checkImmutable(object, loc);
- items.add(object);
+ itemsBuilder.add(object);
}
} else {
throw new EvalException(
@@ -151,12 +150,14 @@ public final class SkylarkNestedSet implements SkylarkValue, SkylarkQueryable {
"cannot union value of type '%s' to a depset", EvalUtils.getDataTypeName(item)));
}
this.contentType = Preconditions.checkNotNull(contentType, "type cannot be null");
+ this.items = itemsBuilder.build();
+ this.transitiveItems = transitiveItemsBuilder.build();
// Initializing the real nested set
NestedSetBuilder<Object> builder = new NestedSetBuilder<>(order);
- builder.addAll(items);
+ builder.addAll(this.items);
try {
- for (NestedSet<?> nestedSet : transitiveItems) {
+ for (NestedSet<?> nestedSet : this.transitiveItems) {
builder.addTransitive(nestedSet);
}
} catch (IllegalArgumentException e) {
@@ -164,8 +165,6 @@ public final class SkylarkNestedSet implements SkylarkValue, SkylarkQueryable {
throw new EvalException(loc, e.getMessage());
}
this.set = builder.build();
- this.items = ImmutableList.copyOf(items);
- this.transitiveItems = ImmutableList.copyOf(transitiveItems);
}
/**