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