summaryrefslogtreecommitdiff
path: root/src/reflect
diff options
context:
space:
mode:
authorDenys Shabalin <denys.shabalin@typesafe.com>2014-03-25 14:57:19 +0100
committerDenys Shabalin <denys.shabalin@typesafe.com>2014-03-25 15:44:07 +0100
commitf10d7541c9c2ddbb3a9cd1a1db800a2fef5a9082 (patch)
tree07c3f028b12da4f22cc1e17b76dd8492e19bc7e5 /src/reflect
parent2fea9502242265e365be987b45e130ac9669d692 (diff)
downloadscala-f10d7541c9c2ddbb3a9cd1a1db800a2fef5a9082.tar.gz
scala-f10d7541c9c2ddbb3a9cd1a1db800a2fef5a9082.tar.bz2
scala-f10d7541c9c2ddbb3a9cd1a1db800a2fef5a9082.zip
SI-8387 don't match new as a function application
Diffstat (limited to 'src/reflect')
-rw-r--r--src/reflect/scala/reflect/internal/ReificationSupport.scala13
1 files changed, 9 insertions, 4 deletions
diff --git a/src/reflect/scala/reflect/internal/ReificationSupport.scala b/src/reflect/scala/reflect/internal/ReificationSupport.scala
index 3aab3f75d4..93cc022a60 100644
--- a/src/reflect/scala/reflect/internal/ReificationSupport.scala
+++ b/src/reflect/scala/reflect/internal/ReificationSupport.scala
@@ -241,10 +241,15 @@ trait ReificationSupport { self: SymbolTable =>
case UnApply(treeInfo.Unapplied(Select(fun, nme.unapply)), pats) =>
Some((fun, pats :: Nil))
case treeInfo.Applied(fun, targs, argss) =>
- val callee =
- if (fun.isTerm) SyntacticTypeApplied(fun, targs)
- else SyntacticAppliedType(fun, targs)
- Some((callee, argss))
+ fun match {
+ case Select(_: New, nme.CONSTRUCTOR) =>
+ Some((tree, Nil))
+ case _ =>
+ val callee =
+ if (fun.isTerm) SyntacticTypeApplied(fun, targs)
+ else SyntacticAppliedType(fun, targs)
+ Some((callee, argss))
+ }
}
}