Не совсем возможно, как вы говорите, но вы можете сделать это, используя шаблон класса type. Например, с здесь :
sealed abstract class Acceptable[T]
object Acceptable {
implicit object IntOk extends Acceptable[Int]
implicit object LongOk extends Acceptable[Long]
}
def f[T: Acceptable](t: T) = t
scala> f(1)
res0: Int = 1
scala> f(1L)
res1: Long = 1
scala> f(1.0)
<console>:8: error: could not find implicit value for parameter ev: Acceptable[Double]
f(1.0)
^
EDIT
Это работает, если класс и объект являются компаньонами. На REPL, если вы печатаете каждый из них в отдельной строке (то есть между ними появляется «результат»), они не являются компаньонами. Вы можете ввести его, как показано ниже:
scala> sealed abstract class Acceptable[T]; object Acceptable {
| implicit object IntOk extends Acceptable[Int]
| implicit object LongOk extends Acceptable[Long]
| }
defined class Acceptable
defined module Acceptable