All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scodec.codecs.ShortCodec.scala Maven / Gradle / Ivy

package scodec
package codecs

import scalaz.\/
import scalaz.syntax.std.either._
import scalaz.syntax.std.option._

import java.nio.{ ByteBuffer, ByteOrder }

import scodec.bits.{ BitVector, ByteOrdering, ByteVector }

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 def description = s"$bits-bit ${if (signed) "signed" else "unsigned"} short"

  override def encode(s: Short) = {
    if (s > MaxValue) {
      \/.left(s"$s is greater than maximum value $MaxValue for $description")
    } else if (s < MinValue) {
      \/.left(s"$s is less than minimum value $MinValue for $description")
    } else {
      \/.right(BitVector.fromShort(s, bits, ordering))
    }
  }

  override def decode(buffer: BitVector) =
    buffer.acquire(bits) match {
      case Left(e) => \/.left(e)
      case Right(b) => \/.right((buffer.drop(bits), b.toShort(signed, ordering)))
    }

  override def toString = description
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy