public static class BeamSqlRecordHelper.TimeCoder extends CustomCoder<java.util.GregorianCalendar>
Coder.Context, Coder.NonDeterministicException
Modifier and Type | Method and Description |
---|---|
java.util.GregorianCalendar |
decode(java.io.InputStream inStream)
Decodes a value of type
T from the given input stream in
the given context. |
void |
encode(java.util.GregorianCalendar value,
java.io.OutputStream outStream)
Encodes the given value of type
T onto the given output stream. |
static BeamSqlRecordHelper.TimeCoder |
of() |
void |
verifyDeterministic()
Throw
Coder.NonDeterministicException if the coding is not deterministic. |
getCoderArguments
consistentWithEquals, decode, encode, getEncodedElementByteSize, getEncodedTypeDescriptor, isRegisterByteSizeObserverCheap, registerByteSizeObserver, structuralValue, verifyDeterministic, verifyDeterministic
public static BeamSqlRecordHelper.TimeCoder of()
public void encode(java.util.GregorianCalendar value, java.io.OutputStream outStream) throws CoderException, java.io.IOException
Coder
T
onto the given output stream.encode
in class Coder<java.util.GregorianCalendar>
CoderException
- if the value could not be encoded for some reasonjava.io.IOException
- if writing to the OutputStream
fails
for some reasonpublic java.util.GregorianCalendar decode(java.io.InputStream inStream) throws CoderException, java.io.IOException
Coder
T
from the given input stream in
the given context. Returns the decoded value.decode
in class Coder<java.util.GregorianCalendar>
CoderException
- if the value could not be decoded for some reasonjava.io.IOException
- if reading from the InputStream
fails
for some reasonpublic void verifyDeterministic() throws Coder.NonDeterministicException
CustomCoder
Coder.NonDeterministicException
if the coding is not deterministic.
In order for a Coder
to be considered deterministic,
the following must be true:
Object.equals()
or Comparable.compareTo()
, if supported) have the same
encoding.
Coder
always produces a canonical encoding, which is the
same for an instance of an object even if produced on different
computers at different times.
verifyDeterministic
in class CustomCoder<java.util.GregorianCalendar>
Coder.NonDeterministicException
- if this coder is not deterministic.