1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
class A {
def foo(x: String, y: Int) = 1
def foo(x: Int, y: String) = 2
}
object Test extends App {
val cm = reflect.runtime.currentMirror
val u = cm.universe
val a = new A
val im = cm.reflect(a)
val tpe = u.typeOf[A]
val overloaded = tpe member u.newTermName("foo") asTermSymbol
val ms1 =
overloaded resolveOverloaded(nameVargs = Seq((u.newTermName("x"), u.typeOf[String]), (u.newTermName("y"), u.typeOf[Int])))
val ms2 =
overloaded resolveOverloaded(nameVargs = Seq((u.newTermName("y"), u.typeOf[Int]), (u.newTermName("x"), u.typeOf[String])))
val ms3 =
overloaded resolveOverloaded(nameVargs = Seq((u.newTermName("x"), u.typeOf[Int]), (u.newTermName("y"), u.typeOf[String])))
val ms4 =
overloaded resolveOverloaded(nameVargs = Seq((u.newTermName("y"), u.typeOf[String]), (u.newTermName("x"), u.typeOf[Int])))
assert(im.reflectMethod(ms1 asMethodSymbol)("A", 1) == 1)
assert(im.reflectMethod(ms2 asMethodSymbol)("A", 1) == 1)
assert(im.reflectMethod(ms3 asMethodSymbol)(1, "A") == 2)
assert(im.reflectMethod(ms4 asMethodSymbol)(1, "A") == 2)
}
|