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

monocle.refined.internal.Bits.scala Maven / Gradle / Ivy

package monocle.refined.internal

import scala.math.signum

private[monocle] trait Bits[A] {
  def bitwiseAnd(a1: A, a2: A): A
  def bitwiseOr(a1: A, a2: A): A
  def bitwiseXor(a1: A, a2: A): A

  def shiftL(a: A, n: Int): A
  def shiftR(a: A, n: Int): A

  // create an A with a single bit set at position n
  def singleBit(n: Int): A

  def updateBit(newValue: Boolean)(a: A, n: Int): A = if (newValue) setBit(a, n) else clearBit(a, n)

  def setBit(a: A, n: Int): A   = bitwiseOr(a, singleBit(n))
  def clearBit(a: A, n: Int): A = bitwiseAnd(a, negate(singleBit(n)))

  def testBit(a: A, n: Int): Boolean

  def negate(a: A): A
  def signed(a: A): Boolean
}

private[monocle] object Bits extends BitsInstances

private[monocle] trait BitsInstances {
  implicit val booleanBits: Bits[Boolean] = new Bits[Boolean] {
    def bitwiseOr(a1: Boolean, a2: Boolean): Boolean  = a1 | a2
    def bitwiseAnd(a1: Boolean, a2: Boolean): Boolean = a1 & a2
    def bitwiseXor(a1: Boolean, a2: Boolean): Boolean = a1 ^ a2

    def singleBit(n: Int): Boolean = true

    def shiftL(a: Boolean, n: Int): Boolean = false
    def shiftR(a: Boolean, n: Int): Boolean = false

    def testBit(a: Boolean, n: Int): Boolean = a

    def signed(a: Boolean): Boolean = a

    def negate(a: Boolean): Boolean = !a
  }

  implicit val byteBits: Bits[Byte] = new Bits[Byte] {
    def bitwiseOr(a1: Byte, a2: Byte): Byte  = (a1 | a2).toByte
    def bitwiseAnd(a1: Byte, a2: Byte): Byte = (a1 & a2).toByte
    def bitwiseXor(a1: Byte, a2: Byte): Byte = (a1 ^ a2).toByte

    def singleBit(n: Int): Byte = (1 << n).toByte

    def shiftL(a: Byte, n: Int): Byte = (a << n).toByte
    def shiftR(a: Byte, n: Int): Byte = (a >> n).toByte

    def testBit(a: Byte, n: Int): Boolean = bitwiseAnd(a, singleBit(n)) != 0

    def signed(a: Byte): Boolean = signum(a) > 0

    def negate(a: Byte): Byte = (~a).toByte
  }

  implicit val charBits: Bits[Char] = new Bits[Char] {
    def bitwiseOr(a1: Char, a2: Char): Char  = (a1 | a2).toChar
    def bitwiseAnd(a1: Char, a2: Char): Char = (a1 & a2).toChar
    def bitwiseXor(a1: Char, a2: Char): Char = (a1 ^ a2).toChar

    def shiftL(a: Char, n: Int): Char = (a << n).toChar
    def shiftR(a: Char, n: Int): Char = (a >> n).toChar

    def singleBit(n: Int): Char = (1 << n).toChar

    def testBit(a: Char, n: Int): Boolean = bitwiseAnd(a, singleBit(n)) != 0

    def negate(a: Char): Char    = (~a).toChar
    def signed(a: Char): Boolean = signum(a) > 0
  }

  implicit val intBits: Bits[Int] = new Bits[Int] {
    def bitwiseOr(a1: Int, a2: Int): Int  = a1 | a2
    def bitwiseAnd(a1: Int, a2: Int): Int = a1 & a2
    def bitwiseXor(a1: Int, a2: Int): Int = a1 ^ a2

    def singleBit(n: Int): Int = 1 << n

    def shiftL(a: Int, n: Int): Int = a << n
    def shiftR(a: Int, n: Int): Int = a >> n

    def testBit(a: Int, n: Int): Boolean = bitwiseAnd(a, singleBit(n)) != 0

    def signed(a: Int): Boolean = signum(a) > 0

    def negate(a: Int): Int = ~a
  }

  implicit val longBits: Bits[Long] = new Bits[Long] {
    def signed(a: Long): Boolean          = signum(a) > 0
    def negate(a: Long): Long             = ~a
    def testBit(a: Long, n: Int): Boolean = bitwiseAnd(a, singleBit(n)) != 0
    def singleBit(n: Int): Long           = 1L << n

    def shiftR(a: Long, n: Int): Long        = a >> n
    def shiftL(a: Long, n: Int): Long        = a << n
    def bitwiseXor(a1: Long, a2: Long): Long = a1 ^ a2
    def bitwiseOr(a1: Long, a2: Long): Long  = a1 | a2
    def bitwiseAnd(a1: Long, a2: Long): Long = a1 & a2
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy