File: hashCodeBoxesRunTime.scala

package info (click to toggle)
scala 2.11.12-4
  • links: PTS, VCS
  • area: main
  • in suites: bullseye, buster
  • size: 62,776 kB
  • sloc: java: 13,415; xml: 3,252; sh: 1,620; python: 756; makefile: 38; awk: 36; ansic: 6
file content (28 lines) | stat: -rw-r--r-- 874 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
// This only tests direct access to the methods in BoxesRunTime,
// not the whole scheme.
object Test
{
  import java.{ lang => jl }
  import scala.runtime.BoxesRunTime.{ hashFromNumber, hashFromObject }

  def allSame[T](xs: List[T]) = assert(xs.distinct.size == 1, "failed: " + xs)

  def mkNumbers(x: Int): List[Number] =
    List(x.toByte, x.toShort, x, x.toLong, x.toFloat, x.toDouble)

  def testLDF(x: Long) = allSame(List[Number](x, x.toDouble, x.toFloat) map hashFromNumber)

  def main(args: Array[String]): Unit = {
    List(Byte.MinValue, -1, 0, 1, Byte.MaxValue) foreach { n =>
      val hashes = mkNumbers(n) map hashFromNumber
      allSame(hashes)
      if (n >= 0) {
        val charCode = hashFromObject(n.toChar: Character)
        assert(charCode == hashes.head)
      }
    }

    testLDF(Short.MaxValue.toLong)
    testLDF(Short.MinValue.toLong)
  }
}