diff options
author | Paul Phillips <paulp@improving.org> | 2012-07-06 12:48:52 -0700 |
---|---|---|
committer | Paul Phillips <paulp@improving.org> | 2012-07-06 14:20:15 -0700 |
commit | 724b0dc71f1f8f91b995d01e9e027789f54ecdfe (patch) | |
tree | 5155c036949eb43d5bbb661bbbc5d18ffe3cc987 /project | |
parent | c632aaca8bdf1dc7c8eac24f5dd0acb18b4683b6 (diff) | |
download | scala-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 'project')
0 files changed, 0 insertions, 0 deletions