diff options
author | Martin Odersky <odersky@gmail.com> | 2013-12-22 18:34:00 +0100 |
---|---|---|
committer | Martin Odersky <odersky@gmail.com> | 2013-12-22 18:58:18 +0100 |
commit | 6ed666c4be5bc4904c926a265d711b85f729d4b3 (patch) | |
tree | bfd51f640ecd89eb3a6d111213747af77c68dde2 /src/dotty/tools/dotc/parsing/Parsers.scala | |
parent | 108be8880688653de490975f29f6ae469e9f3e6a (diff) | |
download | dotty-6ed666c4be5bc4904c926a265d711b85f729d4b3.tar.gz dotty-6ed666c4be5bc4904c926a265d711b85f729d4b3.tar.bz2 dotty-6ed666c4be5bc4904c926a265d711b85f729d4b3.zip |
Typing by-name parameters with ExprTypes.
To avoid duplication between by-name parameters and expr types, we treat by-name parameters as as having ExprType. A part of this is introducing ByNameTypeTree, a specific tree class for => T types.
Diffstat (limited to 'src/dotty/tools/dotc/parsing/Parsers.scala')
-rw-r--r-- | src/dotty/tools/dotc/parsing/Parsers.scala | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/dotty/tools/dotc/parsing/Parsers.scala b/src/dotty/tools/dotc/parsing/Parsers.scala index 85289ee0f..f3f87daff 100644 --- a/src/dotty/tools/dotc/parsing/Parsers.scala +++ b/src/dotty/tools/dotc/parsing/Parsers.scala @@ -647,7 +647,7 @@ object Parsers { atPos(start, in.skipToken()) { Function(ts, typ()) } else { for (t <- ts) - if (isByNameParamType(t)) + if (t.isInstanceOf[ByNameTypeTree]) syntaxError("no by-name parameter type allowed here", t.pos) val tuple = atPos(start) { makeTupleOrParens(ts) } infixTypeRest(refinedTypeRest(withTypeRest(simpleTypeRest(tuple)))) @@ -748,7 +748,7 @@ object Parsers { /** FunArgType ::= ArgType | `=>' ArgType */ val funArgType = () => - if (in.token == ARROW) atPos(in.skipToken()) { PrefixOp(nme.ARROWkw, argType()) } + if (in.token == ARROW) atPos(in.skipToken()) { ByNameTypeTree(argType()) } else argType() /** ParamType ::= FunArgType | ArgType `*' |