aboutsummaryrefslogtreecommitdiff
path: root/src/dotty
diff options
context:
space:
mode:
authorDmitry Petrashko <dark@d-d.me>2016-11-16 15:16:48 +0100
committerGitHub <noreply@github.com>2016-11-16 15:16:48 +0100
commitadb37eee8974be841ff5eef2655c23394c05badb (patch)
tree6147fb435301731bdbb00af74a551b9fcd726c9b /src/dotty
parent443f93f38e3e4bbc346ff945eb0fa51939f3d3a9 (diff)
parent4b1f5daa63afc29d4d7f8c5959e56d2e8bc998e1 (diff)
downloaddotty-adb37eee8974be841ff5eef2655c23394c05badb.tar.gz
dotty-adb37eee8974be841ff5eef2655c23394c05badb.tar.bz2
dotty-adb37eee8974be841ff5eef2655c23394c05badb.zip
Merge pull request #1697 from dotty-staging/fix-#1664
Fix #1664: Refine isOuterRef condition
Diffstat (limited to 'src/dotty')
-rw-r--r--src/dotty/tools/dotc/transform/ExplicitOuter.scala20
1 files changed, 12 insertions, 8 deletions
diff --git a/src/dotty/tools/dotc/transform/ExplicitOuter.scala b/src/dotty/tools/dotc/transform/ExplicitOuter.scala
index 3f235dca7..3fec47e9f 100644
--- a/src/dotty/tools/dotc/transform/ExplicitOuter.scala
+++ b/src/dotty/tools/dotc/transform/ExplicitOuter.scala
@@ -226,14 +226,18 @@ object ExplicitOuter {
case ref: TermRef =>
if (ref.prefix ne NoPrefix)
!ref.symbol.isStatic && isOuterRef(ref.prefix)
- else if (ref.symbol is Hoistable)
- // ref.symbol will be placed in enclosing class scope by LambdaLift, so it might need
- // an outer path then.
- isOuterSym(ref.symbol.owner.enclosingClass)
- else
- // ref.symbol will get a proxy in immediately enclosing class. If this properly
- // contains the current class, it needs an outer path.
- ctx.owner.enclosingClass.owner.enclosingClass.isContainedIn(ref.symbol.owner)
+ else (
+ (ref.symbol is Hoistable) &&
+ // ref.symbol will be placed in enclosing class scope by LambdaLift, so it might need
+ // an outer path then.
+ isOuterSym(ref.symbol.owner.enclosingClass)
+ ||
+ // If not hoistable, ref.symbol will get a proxy in immediately enclosing class. If this properly
+ // contains the current class, it needs an outer path.
+ // If the symbol is hoistable, it might have free variables for which the same
+ // reasoning applies. See pos/i1664.scala
+ ctx.owner.enclosingClass.owner.enclosingClass.isContainedIn(ref.symbol.owner)
+ )
case _ => false
}
def hasOuterPrefix(tp: Type) = tp match {