diff options
author | CGantert345 <57003061+CGantert345@users.noreply.github.com> | 2021-03-29 14:44:43 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-29 14:44:43 +0200 |
commit | c25be270079ed4fa23d7a5c2a2d5eb8519243fb3 (patch) | |
tree | 011863c021df3e5356f07b056d30d0e7476061e4 /src/main/java/org/uic/barcode/asn1/uper/ByteCoder.java | |
parent | Merge pull request #13 from UnionInternationalCheminsdeFer/time_zone_fix_3 (diff) | |
parent | structure change 1 (diff) | |
download | UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.gz UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.bz2 UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.lz UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.xz UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.zst UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.zip |
Diffstat (limited to 'src/main/java/org/uic/barcode/asn1/uper/ByteCoder.java')
-rw-r--r-- | src/main/java/org/uic/barcode/asn1/uper/ByteCoder.java | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/main/java/org/uic/barcode/asn1/uper/ByteCoder.java b/src/main/java/org/uic/barcode/asn1/uper/ByteCoder.java new file mode 100644 index 0000000..f26a598 --- /dev/null +++ b/src/main/java/org/uic/barcode/asn1/uper/ByteCoder.java @@ -0,0 +1,34 @@ +package org.uic.barcode.asn1.uper; + +import java.lang.annotation.Annotation; +import java.lang.reflect.Field; + +class ByteCoder implements Decoder, Encoder { + + @Override public <T> boolean canEncode(T obj, Annotation[] extraAnnotations) { + return obj instanceof Byte; + } + + @Override public <T> void encode(BitBuffer bitbuffer, T obj, Annotation[] extraAnnotations) throws Asn1EncodingException { + UperEncoder.encodeConstrainedInt(bitbuffer, ((Byte) obj).byteValue() & 0xff, 0, 255); + UperEncoder.logger.debug(String.format("BYTE %s", ((Byte) obj).byteValue())); + } + + @Override public <T> boolean canDecode(Class<T> classOfT, Annotation[] extraAnnotations) { + return Byte.class.isAssignableFrom(classOfT) || byte.class.isAssignableFrom(classOfT); + } + + @SuppressWarnings("unchecked") + @Override public <T> T decode(BitBuffer bitbuffer, + Class<T> classOfT, Field field, + Annotation[] extraAnnotations) { + UperEncoder.logger.debug("BYTE"); + return (T) new Byte((byte) UperEncoder.decodeConstrainedInt(bitbuffer, UperEncoder.newRange(0, 255, false))); + } + + @Override + public <T> T getDefault(Class<T> classOfT, Annotation[] extraAnnotations) { + throw new IllegalArgumentException("Default Byte not yet implemented"); + } + +}
\ No newline at end of file |