diff options
author | Miles Sabin <miles@milessabin.com> | 2016-08-10 09:30:49 +0100 |
---|---|---|
committer | Miles Sabin <miles@milessabin.com> | 2016-11-28 10:49:43 +0000 |
commit | dde13b56f421a6f956abebc58f041acec8744149 (patch) | |
tree | da787e48245d7ddb62fe4f1e1224ebae89fdc161 /test/files/neg/t7046/Macros_1.scala | |
parent | 690ba800ec04f05c0f5e5e369863ab5b9578d42f (diff) | |
download | scala-dde13b56f421a6f956abebc58f041acec8744149.tar.gz scala-dde13b56f421a6f956abebc58f041acec8744149.tar.bz2 scala-dde13b56f421a6f956abebc58f041acec8744149.zip |
Partial fix for SI-7046
Diffstat (limited to 'test/files/neg/t7046/Macros_1.scala')
-rw-r--r-- | test/files/neg/t7046/Macros_1.scala | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/test/files/neg/t7046/Macros_1.scala b/test/files/neg/t7046/Macros_1.scala new file mode 100644 index 0000000000..2a5bf82f62 --- /dev/null +++ b/test/files/neg/t7046/Macros_1.scala @@ -0,0 +1,15 @@ +import scala.language.experimental.macros +import scala.reflect.macros.blackbox.Context + +object Macros { + def impl[T](c: Context)(implicit ttag: c.WeakTypeTag[T]): c.Expr[List[String]] = { + import c.universe._; + val ttpe = ttag.tpe + val tsym = ttpe.typeSymbol.asClass + val subclasses = tsym.knownDirectSubclasses.toList.map(_.name.toString) + + c.Expr[List[String]](q"$subclasses") + } + + def knownDirectSubclasses[T]: List[String] = macro impl[T] +} |