Я хочу иметь возможность неявно преобразовывать кортежи чисел (Ints и double) в векторный объект.
Принимая класс Vector с методом +
case class Vector(x: Double, y:Double){
def + (v:Vector)= new Vector(x+v.x,y+v.y)
}
Моя цель - заставить работать следующий код.
val vec = (1,2)+(.5,.3) // vec == Vector(1.5,2.3)
Я могу заставить его работать на Int
со следующим
implicit def int2vec(t:Tuple2[Int,Int])=new Vector(t._1,t._2)
val vec = (1,2)+(3,4) // vec == Vector(4.0,6.0)
Но происходит сбой, когда я добавляю преобразование для двойного
implicit def int2vec(t:Tuple2[Int,Int])=new Vector(t._1,t._2)
implicit def double2vec(t:Tuple2[Double,Double])=new Vector(t._1,t._2)
val a = (1,2)
val b = (.5,.3)
val c = (1,1)+b // vec = Vector(1.5,1.3)
val d = (1,2)+(.3,.5) // compile error: wrong number of arguments
val e = (1,2)+((.3,.5)) // compile error: type mismatch
Попытка удвоить за каждое предложение Андри
implicit def double2vec(t:Tuple2[Double,Double])=new Vector(t._1,t._2)
val a = (.5,.3)
val b = (1,1)+a // type mismatch found:(Double,Double) required:String
Что мне нужно сделать, чтобы заставить это работать?