summaryrefslogtreecommitdiff
path: root/test/files/pos/t7818.scala
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2013-09-06 17:04:53 +0200
committerJason Zaugg <jzaugg@gmail.com>2013-09-06 17:20:27 +0200
commitcb028ba477f37778bccfc23e597acc0284259681 (patch)
treeebe913a6dfb1bb29fd30e1448f66ce6e9150da6e /test/files/pos/t7818.scala
parentd46519da657ada39d9928308709cdb80ddcd53ce (diff)
downloadscala-cb028ba477f37778bccfc23e597acc0284259681.tar.gz
scala-cb028ba477f37778bccfc23e597acc0284259681.tar.bz2
scala-cb028ba477f37778bccfc23e597acc0284259681.zip
SI-7818 Cast our way out of extended existential angst
`substituteSymbols` is not sophisticated enough to operate on `TypeSkolem`-s which are based on one of the "from" symbols. The pertinant usage of `substituteSymbols` for this bug in in `Extender`. Recapping on that transform: // orig class C[T](...) extends AnyVal { def foo[U] = <rhs> } // transform class C[T] extends AnyVal { ... } object C { def foo$extension[T', U'] = <rhs'> } Where `<rhs'>` has been subtituted with, among other things, `[T, U] ~> [T', U']`. In this case our expected type contains a new type parameter (of the extension method), whereas the type of the RHS contains an existential skolem still pinned to the corresponding class type parameter. tree.tpe = Observable1#7037[_$1#12344] <_$1#12344>.info = <: T#7040 pt = Observable1#7037[T#15644] The limitation of substution is lamented in the comments of `adaptMismatchedSkolems`, which faces the harder version of the issue where the skolems are in the expected type. But, we're in the "easy" case with the skolems in the tree's type; we can cast our way out of the problem. See also f335e447 / ed915c54.
Diffstat (limited to 'test/files/pos/t7818.scala')
-rw-r--r--test/files/pos/t7818.scala10
1 files changed, 10 insertions, 0 deletions
diff --git a/test/files/pos/t7818.scala b/test/files/pos/t7818.scala
new file mode 100644
index 0000000000..77b99e7d5d
--- /dev/null
+++ b/test/files/pos/t7818.scala
@@ -0,0 +1,10 @@
+class Observable1[+T](val asJava: JObservable[_ <: T]) extends AnyVal {
+ private def foo[X](a: JObservable[X]): JObservable[X] = ???
+ // was generating a type error as the type of the RHS included an existential
+ // skolem based on the class type parameter `T`, which did not conform
+ // to the typer parameter of the extension method into which the RHS is
+ // transplanted.
+ def synchronize: Observable1[T] = new Observable1(foo(asJava))
+}
+
+class JObservable[T]