summaryrefslogtreecommitdiff
path: root/test/files/run/impconvtimes.scala
blob: 477a16a8903d691cd432aedc049116faee65db56 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import scala.language.implicitConversions

object Test {
  abstract class Unit
  object NoUnit extends Unit
  object Hour extends Unit { override def toString = "Hour" }

  case class Measure(scalar: Double, unit: Unit) {
    def *(newUnit: Unit) = Measure(scalar, newUnit)
  }

  implicit def double2Measure(scalar: Double) =
    Measure(scalar, NoUnit)


  def main(args: Array[String]): scala.Unit = {
    Console.println("3.0 * Hour = " + (3.0 * Hour))
  }
}