import scala.reflect.macros.WhiteboxContext object Macros { def impl[T](c: WhiteboxContext)(implicit T: c.WeakTypeTag[T]) = { import c.universe._ import definitions._ val fields = T.tpe.declarations.toList.collect{ case x: TermSymbol if x.isVal && x.isCaseAccessor => x } val Repr = appliedType(TupleClass(fields.length).asType.toType, fields.map(_.typeSignature)) q"new Generic[$T]{ type Repr = $Repr }" } }