summaryrefslogtreecommitdiff
path: root/src/reflect/scala/reflect/internal/StdNames.scala
diff options
context:
space:
mode:
authorLukas Rytz <lukas.rytz@gmail.com>2014-08-20 13:17:16 +0200
committerLukas Rytz <lukas.rytz@gmail.com>2014-08-20 13:41:01 +0200
commitf324ca5e14d29f8b4f6f7bbacc1c17f4233cd260 (patch)
treec735c3f233ddadb79b7760a443b29697e2af3bec /src/reflect/scala/reflect/internal/StdNames.scala
parent5e0880fe05fb65a8757721be7e5be6a3259c19a8 (diff)
downloadscala-f324ca5e14d29f8b4f6f7bbacc1c17f4233cd260.tar.gz
scala-f324ca5e14d29f8b4f6f7bbacc1c17f4233cd260.tar.bz2
scala-f324ca5e14d29f8b4f6f7bbacc1c17f4233cd260.zip
SI-8803 generate super accessor for super[A], if A is outer superclass
class C extends A with T { class I { C.super[T] C.super[A] } } A super call in a nested class of the form super[T] where T is a parent trait of the outer class doesn't need an accessor: mixin can directly re-route the call to the correct implementation class - it's statically known to be T$class. However, if a nested class accesses super[A] and A is the superclass of the outer class (not a trait), then we need a super accessor in the outer class. We need to add the mixin name to the super accessor name, otherwise it clashes with non-qualified super accessors.
Diffstat (limited to 'src/reflect/scala/reflect/internal/StdNames.scala')
-rw-r--r--src/reflect/scala/reflect/internal/StdNames.scala2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/reflect/scala/reflect/internal/StdNames.scala b/src/reflect/scala/reflect/internal/StdNames.scala
index 6848c357c5..d203218c09 100644
--- a/src/reflect/scala/reflect/internal/StdNames.scala
+++ b/src/reflect/scala/reflect/internal/StdNames.scala
@@ -473,7 +473,7 @@ trait StdNames {
)
def localDummyName(clazz: Symbol): TermName = newTermName(LOCALDUMMY_PREFIX + clazz.name + ">")
- def superName(name: Name): TermName = newTermName(SUPER_PREFIX_STRING + name)
+ def superName(name: Name, mix: Name = EMPTY): TermName = newTermName(SUPER_PREFIX_STRING + name + (if (mix.isEmpty) "" else "$" + mix))
/** The name of an accessor for protected symbols. */
def protName(name: Name): TermName = newTermName(PROTECTED_PREFIX + name)