File: hashCodeBoxesRunTime.scala

package info (click to toggle)
scala 2.9.2%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 67,252 kB
  • ctags: 6,602
  • sloc: java: 27,488; xml: 4,412; python: 2,297; sh: 734; makefile: 16; ansic: 6
file content (28 lines) | stat: -rw-r--r-- 888 bytes parent folder | download | duplicates (2)
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)
  }
}