blob: 4e97cdf9d29db3a2d8132a171b6f23fa79c477d3 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
trait Generic[T] { type Repr }
object Generic {
type Aux[T, Repr0] = Generic[T] { type Repr = Repr0 }
import scala.language.experimental.macros
implicit def materializeGeneric[T, Repr]: Generic.Aux[T, Repr] = macro Macros.impl[T]
}
object Test extends dotty.runtime.LegacyApp {
case class C(x: Int, y: Int)
import scala.reflect.runtime.universe._
def reprify[T, Repr](x: T)(implicit generic: Generic.Aux[T, Repr], tag: WeakTypeTag[Repr]) = {
println(tag)
println(tag.tpe.typeSymbol.info)
}
reprify(C(40, 2))
implicitly[Generic.Aux[C, (Int, Int)]]
}
|