Элемент типа S
в Calc
затеняется параметром типа S
метода recalc
.
Вторая ошибка: абстрактный тип S
должен быть определен в классе Price
.
Должно работать следующее:
sealed trait SeqValue {
def seq:Int
def value:Float
override def toString = ToStringBuilder.reflectionToString(this, ToStringStyle.SHORT_PREFIX_STYLE)
}
sealed trait Calc {
type S <: SeqValue
def recalc(input:S):SeqValue
}
case class Price(seq:Int=0, value:Float=.0f) extends SeqValue with Calc {
type S = SeqValue
def recalc(input:SeqValue) = Price(1 + seq, input.value)
}
Редактировать: (в ответ на комментарий)
Я не понимаю, что именно вы пытаетесь сделать, но вы могли бы выделить определение типа в отдельной черте миксина.
trait SAsSeqValue {
type S = SeqValue
}
case class Price(seq:Int=0, value:Float=.0f) extends SeqValue with Calc with SAsSeqValue {
def recalc(input:SeqValue) = Price(1 + seq, input.value)
}