scodec.codecs.ShortCodec.scala Maven / Gradle / Ivy
package scodec
package codecs
import scodec.bits.{ BitVector, ByteOrdering }
private[codecs] final class ShortCodec(bits: Int, signed: Boolean, ordering: ByteOrdering) extends Codec[Short] {
require(bits > 0 && bits <= (if (signed) 16 else 15), "bits must be in range [1, 16] for signed and [1, 15] for unsigned")
val MaxValue = ((1 << (if (signed) (bits - 1) else bits)) - 1).toShort
val MinValue = (if (signed) -(1 << (bits - 1)) else 0).toShort
private val bitsL = bits.toLong
private def description = s"$bits-bit ${if (signed) "signed" else "unsigned"} short"
override def sizeBound = SizeBound.exact(bits.toLong)
override def encode(s: Short) = {
if (s > MaxValue) {
Attempt.failure(Err(s"$s is greater than maximum value $MaxValue for $description"))
} else if (s < MinValue) {
Attempt.failure(Err(s"$s is less than minimum value $MinValue for $description"))
} else {
Attempt.successful(BitVector.fromShort(s, bits, ordering))
}
}
override def decode(buffer: BitVector) = {
if (buffer.sizeGreaterThanOrEqual(bitsL))
Attempt.successful(DecodeResult(buffer.take(bitsL).toShort(signed, ordering), buffer.drop(bitsL)))
else
Attempt.failure(Err.insufficientBits(bitsL, buffer.size))
}
override def toString = description
}