diff options
author | 2018-03-02 17:48:57 -0800 | |
---|---|---|
committer | 2018-03-02 17:51:19 -0800 | |
commit | 5fb2a487e53cc3d80e3654d5b63d062f7f70588b (patch) | |
tree | 82b23b68d09c451a8950468668150acdf89533e9 /src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternsValue.java | |
parent | 46f7106d0b20ae0ba245c3609545600ae379cea4 (diff) |
Replace LegacySkyKey by AbstractSkyKey or custom SkyKeys. AbstractSkyKey doesn't save memory in the 32-bit case, but makes it easier for people to see how many SkyKeys we have.
There's some unnecessary interning in tests, but it was easier to copypasta and doesn't harm anything, I think.
PiperOrigin-RevId: 187694309
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternsValue.java')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternsValue.java | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternsValue.java b/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternsValue.java index 6c915658f4..037fd7c608 100644 --- a/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternsValue.java +++ b/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternsValue.java @@ -16,14 +16,15 @@ package com.google.devtools.build.lib.skyframe; import com.google.common.base.MoreObjects; import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableList; +import com.google.common.collect.Interner; +import com.google.devtools.build.lib.concurrent.BlazeInterners; import com.google.devtools.build.lib.concurrent.ThreadSafety.Immutable; import com.google.devtools.build.lib.concurrent.ThreadSafety.ThreadSafe; import com.google.devtools.build.lib.skyframe.TargetPatternValue.TargetPatternKey; import com.google.devtools.build.lib.skyframe.serialization.autocodec.AutoCodec; -import com.google.devtools.build.skyframe.LegacySkyKey; +import com.google.devtools.build.skyframe.SkyFunctionName; import com.google.devtools.build.skyframe.SkyKey; import com.google.devtools.build.skyframe.SkyValue; -import java.io.Serializable; import java.util.Objects; /** @@ -55,22 +56,32 @@ public final class PrepareDepsOfPatternsValue implements SkyValue { } @ThreadSafe - public static SkyKey key(ImmutableList<String> patterns, String offset) { - return LegacySkyKey.create( - SkyFunctions.PREPARE_DEPS_OF_PATTERNS, new TargetPatternSequence(patterns, offset)); + public static TargetPatternSequence key(ImmutableList<String> patterns, String offset) { + return TargetPatternSequence.create(patterns, offset); } /** The argument value for {@link SkyKey}s of {@link PrepareDepsOfPatternsFunction}. */ @ThreadSafe - public static class TargetPatternSequence implements Serializable { + @AutoCodec.VisibleForSerialization + @AutoCodec + static class TargetPatternSequence implements SkyKey { + private static final Interner<TargetPatternSequence> interner = + BlazeInterners.newWeakInterner(); + private final ImmutableList<String> patterns; private final String offset; - public TargetPatternSequence(ImmutableList<String> patterns, String offset) { + private TargetPatternSequence(ImmutableList<String> patterns, String offset) { this.patterns = Preconditions.checkNotNull(patterns); this.offset = Preconditions.checkNotNull(offset); } + @AutoCodec.VisibleForSerialization + @AutoCodec.Instantiator + static TargetPatternSequence create(ImmutableList<String> patterns, String offset) { + return interner.intern(new TargetPatternSequence(patterns, offset)); + } + public ImmutableList<String> getPatterns() { return patterns; } @@ -103,6 +114,11 @@ public final class PrepareDepsOfPatternsValue implements SkyValue { .add("offset", offset) .toString(); } + + @Override + public SkyFunctionName functionName() { + return SkyFunctions.PREPARE_DEPS_OF_PATTERNS; + } } @Override |