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/PrepareDepsOfPatternValue.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/PrepareDepsOfPatternValue.java')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternValue.java | 35 |
1 files changed, 29 insertions, 6 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternValue.java b/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternValue.java index 23383680be..4a1b83062c 100644 --- a/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternValue.java +++ b/src/main/java/com/google/devtools/build/lib/skyframe/PrepareDepsOfPatternValue.java @@ -14,14 +14,17 @@ package com.google.devtools.build.lib.skyframe; import com.google.common.collect.ImmutableList; +import com.google.common.collect.Interner; import com.google.devtools.build.lib.cmdline.TargetParsingException; import com.google.devtools.build.lib.cmdline.TargetPattern.Type; +import com.google.devtools.build.lib.concurrent.BlazeInterners; import com.google.devtools.build.lib.concurrent.ThreadSafety.ThreadSafe; import com.google.devtools.build.lib.pkgcache.FilteringPolicies; import com.google.devtools.build.lib.skyframe.TargetPatternValue.TargetPatternKey; import com.google.devtools.build.lib.skyframe.TargetPatternValue.TargetPatternSkyKeyOrException; import com.google.devtools.build.lib.skyframe.serialization.autocodec.AutoCodec; -import com.google.devtools.build.skyframe.LegacySkyKey; +import com.google.devtools.build.skyframe.AbstractSkyKey; +import com.google.devtools.build.skyframe.SkyFunctionName; import com.google.devtools.build.skyframe.SkyKey; import com.google.devtools.build.skyframe.SkyValue; import java.util.List; @@ -174,16 +177,36 @@ public class PrepareDepsOfPatternValue implements SkyValue { private final TargetPatternKey targetPatternKey; - public PrepareDepsOfPatternSkyKeyValue(TargetPatternKey targetPatternKey) { + PrepareDepsOfPatternSkyKeyValue(TargetPatternKey targetPatternKey) { this.targetPatternKey = targetPatternKey; } - public SkyKey getSkyKey() { - return LegacySkyKey.create(SkyFunctions.PREPARE_DEPS_OF_PATTERN, targetPatternKey); + public Key getSkyKey() { + return Key.create(targetPatternKey); } - public String getOriginalPattern() { - return targetPatternKey.getPattern(); + @AutoCodec + static class Key extends AbstractSkyKey<TargetPatternKey> { + private static final Interner<Key> interner = BlazeInterners.newWeakInterner(); + + private Key(TargetPatternKey arg) { + super(arg); + } + + @AutoCodec.VisibleForSerialization + @AutoCodec.Instantiator + static Key create(TargetPatternKey arg) { + return interner.intern(new Key(arg)); + } + + TargetPatternKey getTargetPatternKey() { + return arg; + } + + @Override + public SkyFunctionName functionName() { + return SkyFunctions.PREPARE_DEPS_OF_PATTERN; + } } } } |