summaryrefslogtreecommitdiff
path: root/test/files/run
diff options
context:
space:
mode:
authorLukas Rytz <lukas.rytz@typesafe.com>2015-10-27 09:03:15 +0100
committerLukas Rytz <lukas.rytz@typesafe.com>2015-10-27 09:03:15 +0100
commit4321ea458ad1258f273ee22a4c6a7606ab054501 (patch)
treefe68843b632bda3eed3066a83f66b5249dbb86dd /test/files/run
parentb194a4e7230334e441cd31b617fdce8e329dfa3a (diff)
parent4a5a800d4606d917289dc14c35f2035e83f58953 (diff)
downloadscala-4321ea458ad1258f273ee22a4c6a7606ab054501.tar.gz
scala-4321ea458ad1258f273ee22a4c6a7606ab054501.tar.bz2
scala-4321ea458ad1258f273ee22a4c6a7606ab054501.zip
Merge pull request #4820 from lrytz/t9535
SI-9535 correct bytecode and generic signatures for @throws[TypeParam]
Diffstat (limited to 'test/files/run')
-rw-r--r--test/files/run/t9535.scala22
1 files changed, 22 insertions, 0 deletions
diff --git a/test/files/run/t9535.scala b/test/files/run/t9535.scala
new file mode 100644
index 0000000000..62e156e456
--- /dev/null
+++ b/test/files/run/t9535.scala
@@ -0,0 +1,22 @@
+class C[E <: Exception] {
+ @throws[E] def f = 1
+
+ @throws(classOf[Exception]) def g: E = ???
+
+ @throws[E] @throws[Exception] def h = 1
+}
+
+object Test extends App {
+ val c = classOf[C[_]]
+ def sig(method: String) = c.getDeclaredMethod(method).toString
+ def genSig(method: String) = c.getDeclaredMethod(method).toGenericString
+
+ assert(sig("f") == "public int C.f() throws java.lang.Exception")
+ assert(genSig("f") == "public int C.f() throws E")
+
+ assert(sig("g") == "public java.lang.Exception C.g() throws java.lang.Exception")
+ assert(genSig("g") == "public E C.g() throws java.lang.Exception")
+
+ assert(sig("h") == "public int C.h() throws java.lang.Exception,java.lang.Exception")
+ assert(genSig("h") == "public int C.h() throws E,java.lang.Exception")
+}