in daffodil-lib/src/main/scala/passera/unsigned/SmallUInt.scala [46:126]
def toBigInt = JBigInt.valueOf(intValue)
def toUByte = UByte(intValue.toByte)
def toUShort = UShort(intValue.toShort)
def toUInt = UInt(intValue)
def toULong = ULong(intValue & 0xffffffffL)
override def byteValue = intValue.toByte
override def shortValue = intValue.toShort
override def intValue: Int
override def longValue = (intValue & 0xffffffffL)
override def floatValue = (intValue & 0xffffffffL).toFloat
override def doubleValue = (intValue & 0xffffffffL).toDouble
def +(x: Int)(implicit d: DummyImplicit): Int = this.toInt + x
def -(x: Int)(implicit d: DummyImplicit): Int = this.toInt - x
def *(x: Int)(implicit d: DummyImplicit): Int = this.toInt * x
def /(x: Int)(implicit d: DummyImplicit): Int = this.toInt / x
def %(x: Int)(implicit d: DummyImplicit): Int = this.toInt % x
def &(x: Int)(implicit d: DummyImplicit): Int = this.toInt & x
def |(x: Int)(implicit d: DummyImplicit): Int = this.toInt | x
def ^(x: Int)(implicit d: DummyImplicit): Int = this.toInt ^ x
def +(x: Long)(implicit d: DummyImplicit): Long = this.toLong + x
def -(x: Long)(implicit d: DummyImplicit): Long = this.toLong - x
def *(x: Long)(implicit d: DummyImplicit): Long = this.toLong * x
def /(x: Long)(implicit d: DummyImplicit): Long = this.toLong / x
def %(x: Long)(implicit d: DummyImplicit): Long = this.toLong % x
def &(x: Long)(implicit d: DummyImplicit): Long = this.toLong & x
def |(x: Long)(implicit d: DummyImplicit): Long = this.toLong | x
def ^(x: Long)(implicit d: DummyImplicit): Long = this.toLong ^ x
def +(x: UByte): UInt = this + x.toUInt
def -(x: UByte): UInt = this - x.toUInt
def *(x: UByte): UInt = this * x.toUInt
def /(x: UByte): UInt = this / x.toUInt
def %(x: UByte): UInt = this % x.toUInt
def &(x: UByte): UInt = this & x.toUInt
def |(x: UByte): UInt = this | x.toUInt
def ^(x: UByte): UInt = this ^ x.toUInt
def <(x: UByte): Boolean = this < x.toUInt
def >(x: UByte): Boolean = this > x.toUInt
def <=(x: UByte): Boolean = this <= x.toUInt
def >=(x: UByte): Boolean = this >= x.toUInt
def +(x: UShort): UInt = this + x.toUInt
def -(x: UShort): UInt = this - x.toUInt
def *(x: UShort): UInt = this * x.toUInt
def /(x: UShort): UInt = this / x.toUInt
def %(x: UShort): UInt = this % x.toUInt
def &(x: UShort): UInt = this & x.toUInt
def |(x: UShort): UInt = this | x.toUInt
def ^(x: UShort): UInt = this ^ x.toUInt
def <(x: UShort): Boolean = this < x.toUInt
def >(x: UShort): Boolean = this > x.toUInt
def <=(x: UShort): Boolean = this <= x.toUInt
def >=(x: UShort): Boolean = this >= x.toUInt
def +(x: ULong): ULong = this.toULong + x
def -(x: ULong): ULong = this.toULong - x
def *(x: ULong): ULong = this.toULong * x
def /(x: ULong): ULong = this.toULong / x
def %(x: ULong): ULong = this.toULong % x
def &(x: ULong): ULong = this.toULong & x
def |(x: ULong): ULong = this.toULong | x
def ^(x: ULong): ULong = this.toULong ^ x
def <(x: ULong): Boolean = this.toULong < x
def >(x: ULong): Boolean = this.toULong > x
def <=(x: ULong): Boolean = this.toULong <= x
def >=(x: ULong): Boolean = this.toULong >= x
def +(x: UInt) = UInt(intValue + x.intValue)
def -(x: UInt) = UInt(intValue - x.intValue)
def *(x: UInt) = UInt(intValue * x.intValue)
def /(x: UInt) = {
val n = intValue & 0xffffffffL
val m = x.intValue & 0xffffffffL
val r = n / m
UInt(r.toInt)
}