summaryrefslogblamecommitdiff
path: root/test/files/run/reflection-implClass.scala
blob: b91f122a231bccb81f826b9f28447a8afd331ab2 (plain) (tree)
1
2
3
4
5
6
7
8
9





                                                                       

                                    
                             
 

                                                                                                        




                                                  
                                                                                           



                                                  
                                                                                           



                                                           




             





               
/** 
 * Tries to load a symbol for the `Foo$class` using Scala reflection.  
 * Since trait implementation classes do not get pickling information
 * symbol for them should be created using fallback mechanism
 * that exposes Java reflection information dressed up in
 * a Scala symbol.
 */
object Test extends App with Outer {
  import scala.reflect.mirror

  assert(mirror.classToSymbol(manifest[Foo].erasure).info.declaration(mirror.newTermName("bar")).info ==
    mirror.classToSymbol(manifest[Bar].erasure).info.declaration(mirror.newTermName("foo")).info)

  val s1 = implClass(manifest[Foo].erasure)
  assert(s1 != mirror.NoSymbol)
  assert(s1.info != mirror.NoType)
  assert(s1.companionModule.info != mirror.NoType)
  assert(s1.companionModule.info.declaration(mirror.newTermName("bar")) != mirror.NoSymbol)
  val s2 = implClass(manifest[Bar].erasure)
  assert(s2 != mirror.NoSymbol)
  assert(s2.info != mirror.NoType)
  assert(s2.companionModule.info != mirror.NoType)
  assert(s2.companionModule.info.declaration(mirror.newTermName("foo")) != mirror.NoSymbol)
  def implClass(clazz: Class[_]) = {
    val implClass = Class.forName(clazz.getName + "$class")
    mirror.classToSymbol(implClass)
  }
}

trait Foo {
  def bar = 1
}

trait Outer {
  trait Bar {
    def foo = 1
  }
}