summaryrefslogtreecommitdiff
path: root/src/compiler/scala/tools/nsc/typechecker/Typers.scala
diff options
context:
space:
mode:
authorPaul Phillips <paulp@improving.org>2012-07-06 12:48:52 -0700
committerPaul Phillips <paulp@improving.org>2012-07-06 14:20:15 -0700
commit724b0dc71f1f8f91b995d01e9e027789f54ecdfe (patch)
tree5155c036949eb43d5bbb661bbbc5d18ffe3cc987 /src/compiler/scala/tools/nsc/typechecker/Typers.scala
parentc632aaca8bdf1dc7c8eac24f5dd0acb18b4683b6 (diff)
downloadscala-724b0dc71f1f8f91b995d01e9e027789f54ecdfe.tar.gz
scala-724b0dc71f1f8f91b995d01e9e027789f54ecdfe.tar.bz2
scala-724b0dc71f1f8f91b995d01e9e027789f54ecdfe.zip
Implicits to encourage more Name-dropping.
This creates implicits in cakes across the land from: String => TermName String => TypeName And also from: Name => NameOps[Name] // lower priority TermName => NameOps[TermName] TypeName => NameOps[TypeName] What this is all about, using "drop" as a motivating example, is that these should all work: "abc" drop 1 // "bc": String ("abc": TermName) drop 1 // "bc": TermName ("abc": TypeName) drop 1 // "bc": TypeName (("abc": TypeName): Name) drop 1 // "bc": Name But this should not: ("bc": Name) // ambiguity error This requires drop not being directly on Name; peer implicits from String => TermName and String => TypeName; implicit classes to install drop on TermName and TypeName; and a lower priority implicit class to allow ops on Names. Review by @xeno.by .
Diffstat (limited to 'src/compiler/scala/tools/nsc/typechecker/Typers.scala')
-rw-r--r--src/compiler/scala/tools/nsc/typechecker/Typers.scala2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/compiler/scala/tools/nsc/typechecker/Typers.scala b/src/compiler/scala/tools/nsc/typechecker/Typers.scala
index ccd346e72d..c675167139 100644
--- a/src/compiler/scala/tools/nsc/typechecker/Typers.scala
+++ b/src/compiler/scala/tools/nsc/typechecker/Typers.scala
@@ -4283,7 +4283,7 @@ trait Typers extends Modes with Adaptations with Tags {
}
def convertToAssignment(fun: Tree, qual: Tree, name: Name, args: List[Tree]): Tree = {
- val prefix = name stripSuffix nme.EQL
+ val prefix = name.toTermName stripSuffix nme.EQL
def mkAssign(vble: Tree): Tree =
Assign(
vble,