summaryrefslogtreecommitdiff
path: root/test/files/run
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2013-03-23 08:59:51 +0100
committerJason Zaugg <jzaugg@gmail.com>2013-03-23 12:52:40 +0100
commitdd89b006218d76a74d0185392d5e427c0867a33c (patch)
tree5d6202ccf02733a0c938fd2ccf008bff5ae84be6 /test/files/run
parent499962d34e83134d622fa319b84664ee2747dd72 (diff)
downloadscala-dd89b006218d76a74d0185392d5e427c0867a33c.tar.gz
scala-dd89b006218d76a74d0185392d5e427c0867a33c.tar.bz2
scala-dd89b006218d76a74d0185392d5e427c0867a33c.zip
SI-7285 Fix match analysis with nested objects.
The fix for SI-6146 introduced `nestedMemberType` to enumerate sealed subtypes based on the (prefixed) type of the scrutinee and the symbols of its sealed subclasses. That method needed to widen `ThisType(modSym)`s to `ModuleTypeRef(modSym)` before calling `asSeenFrom`. However, this could lead to confused in the match analysis, which sees `ModuleTypeRef` as distinct from singleton types on the same modules (after all, they aren't =:=). Spurious warnings ensued. This commit makes two changes: - conditionally re-narrow the result of `asSeenFrom` in `nestedMemberType`. - present `a.b.SomeModule.type` as `SomeModule` in warnings emitted by the pattern matcher.
Diffstat (limited to 'test/files/run')
-rw-r--r--test/files/run/t6146b.check5
1 files changed, 1 insertions, 4 deletions
diff --git a/test/files/run/t6146b.check b/test/files/run/t6146b.check
index e08e40d9fa..49ff70697e 100644
--- a/test/files/run/t6146b.check
+++ b/test/files/run/t6146b.check
@@ -43,10 +43,7 @@ mt1: u.Type = O.X.S1.type
scala> global.typeDeconstruct.show(mt1)
res0: String =
TypeRef(
- pre = TypeRef(
- pre = ThisType(object O)
- TypeSymbol(class X extends AnyRef)
- )
+ pre = SingleType(pre = ThisType(object O), object X)
TypeSymbol(class S1 extends C.this.F[T])
)