diff options
author | michajlo <michajlo@google.com> | 2018-02-11 09:23:55 -0800 |
---|---|---|
committer | Copybara-Service <copybara-piper@google.com> | 2018-02-11 09:25:41 -0800 |
commit | e45c0555cfb15ce403ff2f447edb74495a633ec1 (patch) | |
tree | 28c7a697306b91d00a49602b991aea9476c65892 /src/main/java/com/google/devtools/build/lib/vfs/Root.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/Root.java')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/vfs/Root.java | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/vfs/Root.java b/src/main/java/com/google/devtools/build/lib/vfs/Root.java index 0df98c0c9c..73ff687b56 100644 --- a/src/main/java/com/google/devtools/build/lib/vfs/Root.java +++ b/src/main/java/com/google/devtools/build/lib/vfs/Root.java @@ -15,7 +15,9 @@ package com.google.devtools.build.lib.vfs; import com.google.common.base.Objects; import com.google.common.base.Preconditions; +import com.google.devtools.build.lib.skyframe.serialization.DeserializationContext; import com.google.devtools.build.lib.skyframe.serialization.InjectingObjectCodec; +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; @@ -263,11 +265,15 @@ public interface Root extends Comparable<Root>, Serializable { } @Override - public void serialize(FileSystemProvider dependency, Root obj, CodedOutputStream codedOut) + public void serialize( + FileSystemProvider dependency, + SerializationContext context, + Root obj, + CodedOutputStream codedOut) throws SerializationException, IOException { if (obj instanceof PathRoot) { codedOut.writeBoolNoTag(false); - Path.CODEC.serialize(dependency, ((PathRoot) obj).path, codedOut); + Path.CODEC.serialize(dependency, context, ((PathRoot) obj).path, codedOut); } else if (obj instanceof AbsoluteRoot) { Preconditions.checkArgument(((AbsoluteRoot) obj).fileSystem == dependency.getFileSystem()); codedOut.writeBoolNoTag(true); @@ -277,13 +283,14 @@ public interface Root extends Comparable<Root>, Serializable { } @Override - public Root deserialize(FileSystemProvider dependency, CodedInputStream codedIn) + public Root deserialize( + FileSystemProvider dependency, DeserializationContext context, CodedInputStream codedIn) throws SerializationException, IOException { boolean isAbsolute = codedIn.readBool(); if (isAbsolute) { return dependency.getFileSystem().getAbsoluteRoot(); } else { - Path path = Path.CODEC.deserialize(dependency, codedIn); + Path path = Path.CODEC.deserialize(dependency, context, codedIn); return new PathRoot(path); } } |