summaryrefslogtreecommitdiff
path: root/src/reflect/scala/reflect/internal/TreeGen.scala
diff options
context:
space:
mode:
authorPaul Phillips <paulp@improving.org>2013-06-08 12:04:27 -0700
committerPaul Phillips <paulp@improving.org>2013-06-08 12:04:27 -0700
commit45d61774eb255416c96e983cdb87960ad6415b74 (patch)
tree4aeb3debc1cf0a79ece22175f4be8450b607594b /src/reflect/scala/reflect/internal/TreeGen.scala
parent04837e710552cc53b0b06b2bc47ee7d2856ae230 (diff)
downloadscala-45d61774eb255416c96e983cdb87960ad6415b74.tar.gz
scala-45d61774eb255416c96e983cdb87960ad6415b74.tar.bz2
scala-45d61774eb255416c96e983cdb87960ad6415b74.zip
Eliminate needless Options.
Many of our core types have dedicated sentinels which serve perfectly to communicate "no value", even more perfectly than None. Saving a billion allocations is gravy.
Diffstat (limited to 'src/reflect/scala/reflect/internal/TreeGen.scala')
-rw-r--r--src/reflect/scala/reflect/internal/TreeGen.scala22
1 files changed, 11 insertions, 11 deletions
diff --git a/src/reflect/scala/reflect/internal/TreeGen.scala b/src/reflect/scala/reflect/internal/TreeGen.scala
index 6abf344adb..b75fd72526 100644
--- a/src/reflect/scala/reflect/internal/TreeGen.scala
+++ b/src/reflect/scala/reflect/internal/TreeGen.scala
@@ -137,20 +137,20 @@ abstract class TreeGen extends macros.TreeBuilder {
/** Replaces tree type with a stable type if possible */
def stabilize(tree: Tree): Tree = stableTypeFor(tree) match {
- case Some(tp) => tree setType tp
- case _ => tree
+ case NoType => tree
+ case tp => tree setType tp
}
/** Computes stable type for a tree if possible */
- def stableTypeFor(tree: Tree): Option[Type] =
- if (treeInfo.admitsTypeSelection(tree))
- tree match {
- case This(_) => Some(ThisType(tree.symbol))
- case Ident(_) => Some(singleType(tree.symbol.owner.thisType, tree.symbol))
- case Select(qual, _) => Some(singleType(qual.tpe, tree.symbol))
- case _ => None
- }
- else None
+ def stableTypeFor(tree: Tree): Type = (
+ if (!treeInfo.admitsTypeSelection(tree)) NoType
+ else tree match {
+ case This(_) => ThisType(tree.symbol)
+ case Ident(_) => singleType(tree.symbol.owner.thisType, tree.symbol)
+ case Select(qual, _) => singleType(qual.tpe, tree.symbol)
+ case _ => NoType
+ }
+ )
/** Builds a reference with stable type to given symbol */
def mkAttributedStableRef(pre: Type, sym: Symbol): Tree =