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

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

package scodec
package codecs

import java.nio.ByteBuffer

import scalaz.\/
import scalaz.syntax.std.either._
import scodec.bits.{ BitVector, ByteOrdering }

private[codecs] final class FloatCodec(ordering: ByteOrdering) extends Codec[Float] {

  private val byteOrder = ordering.toJava

  override def encode(value: Float) = {
    val buffer = ByteBuffer.allocate(4).order(ordering.toJava).putFloat(value)
    buffer.flip()
    \/.right(BitVector.view(buffer))
  }

  override def decode(buffer: BitVector) =
    buffer.acquire(32) match {
      case Left(e) => \/.left(e)
      case Right(b) => \/.right((buffer.drop(32), ByteBuffer.wrap(b.toByteArray).order(byteOrder).getFloat))
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy