diff options
author | 2018-02-11 09:23:55 -0800 | |
---|---|---|
committer | 2018-02-11 09:25:41 -0800 | |
commit | e45c0555cfb15ce403ff2f447edb74495a633ec1 (patch) | |
tree | 28c7a697306b91d00a49602b991aea9476c65892 /src/main/java/com/google/devtools/build/lib/vfs/RootedPath.java | |
parent | e3bbfdb839a483f1a418a94d857c25794006fbe0 (diff) |
Add context argument to ObjectCodec.{serialize,deserialize}
Context implementations are currently empty, just doing the plumbing in this
change. Once this is in we can start passing along the ObjectCodecRegistry, which
will allow runtime codec resolution for classes not known at compile time.
We'll also inevitably add some memoization helpers, allowing us to optimize the
serialization process further.
PiperOrigin-RevId: 185305674
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/vfs/RootedPath.java')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/vfs/RootedPath.java | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/vfs/RootedPath.java b/src/main/java/com/google/devtools/build/lib/vfs/RootedPath.java index 82335c7921..aa3153463d 100644 --- a/src/main/java/com/google/devtools/build/lib/vfs/RootedPath.java +++ b/src/main/java/com/google/devtools/build/lib/vfs/RootedPath.java @@ -14,8 +14,10 @@ package com.google.devtools.build.lib.vfs; import com.google.common.base.Preconditions; +import com.google.devtools.build.lib.skyframe.serialization.DeserializationContext; import com.google.devtools.build.lib.skyframe.serialization.InjectingObjectCodecAdapter; import com.google.devtools.build.lib.skyframe.serialization.ObjectCodec; +import com.google.devtools.build.lib.skyframe.serialization.SerializationContext; import com.google.devtools.build.lib.skyframe.serialization.SerializationException; import com.google.protobuf.CodedInputStream; import com.google.protobuf.CodedOutputStream; @@ -138,17 +140,18 @@ public class RootedPath implements Serializable { } @Override - public void serialize(RootedPath rootedPath, CodedOutputStream codedOut) + public void serialize( + SerializationContext context, RootedPath rootedPath, CodedOutputStream codedOut) throws IOException, SerializationException { - rootCodec.serialize(rootedPath.getRoot(), codedOut); - PathFragment.CODEC.serialize(rootedPath.getRootRelativePath(), codedOut); + rootCodec.serialize(context, rootedPath.getRoot(), codedOut); + PathFragment.CODEC.serialize(context, rootedPath.getRootRelativePath(), codedOut); } @Override - public RootedPath deserialize(CodedInputStream codedIn) + public RootedPath deserialize(DeserializationContext context, CodedInputStream codedIn) throws IOException, SerializationException { - Root root = rootCodec.deserialize(codedIn); - PathFragment rootRelativePath = PathFragment.CODEC.deserialize(codedIn); + Root root = rootCodec.deserialize(context, codedIn); + PathFragment rootRelativePath = PathFragment.CODEC.deserialize(context, codedIn); return toRootedPath(root, rootRelativePath); } } |