diff options
author | 2018-04-13 13:33:47 -0700 | |
---|---|---|
committer | 2018-04-13 13:35:19 -0700 | |
commit | ab136c0b099a325edbab5d2939f74b6cabc4f5ab (patch) | |
tree | 2d6d5bad88ca527148bc5a5a538b7443c7e4720e /src/main/java/com/google/devtools | |
parent | 8b47bc0c5f489424d39e5ae4f41f8a192a890bad (diff) |
Add DurationCodec
This is required for moving --test_timeout from ExecutionOptions to BuildConfiguration.Options
PiperOrigin-RevId: 192815911
Diffstat (limited to 'src/main/java/com/google/devtools')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/skyframe/serialization/DurationCodec.java | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/serialization/DurationCodec.java b/src/main/java/com/google/devtools/build/lib/skyframe/serialization/DurationCodec.java new file mode 100644 index 0000000000..0c42fb7bec --- /dev/null +++ b/src/main/java/com/google/devtools/build/lib/skyframe/serialization/DurationCodec.java @@ -0,0 +1,42 @@ +// Copyright 2018 The Bazel Authors. All rights reserved. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package com.google.devtools.build.lib.skyframe.serialization; + +import com.google.protobuf.CodedInputStream; +import com.google.protobuf.CodedOutputStream; +import java.io.IOException; +import java.time.Duration; + +/** Encodes a Duration. */ +public class DurationCodec implements ObjectCodec<Duration> { + + @Override + public void serialize(SerializationContext context, Duration obj, CodedOutputStream codedOut) + throws SerializationException, IOException { + codedOut.writeInt64NoTag(obj.getSeconds()); + codedOut.writeInt32NoTag(obj.getNano()); + } + + @Override + public Duration deserialize(DeserializationContext context, CodedInputStream codedIn) + throws SerializationException, IOException { + return Duration.ofSeconds(codedIn.readInt64(), codedIn.readInt32()); + } + + @Override + public Class<Duration> getEncodedClass() { + return Duration.class; + } +} |