@@ -62,7 +62,7 @@ object Parsers {
62
62
case ExtensionFollow // extension clause, following extension parameter
63
63
64
64
def isClass = // owner is a class
65
- this == Class || this == CaseClass
65
+ this == Class || this == CaseClass || this == Given
66
66
def takesOnlyUsingClauses = // only using clauses allowed for this owner
67
67
this == Given || this == ExtensionFollow
68
68
def acceptsVariance =
@@ -3350,7 +3350,7 @@ object Parsers {
3350
3350
val isAbstractOwner = paramOwner == ParamOwner .Type || paramOwner == ParamOwner .TypeParam
3351
3351
val start = in.offset
3352
3352
var mods = annotsAsMods() | Param
3353
- if paramOwner == ParamOwner . Class || paramOwner == ParamOwner . CaseClass then
3353
+ if paramOwner.isClass then
3354
3354
mods |= PrivateLocal
3355
3355
if isIdent(nme.raw.PLUS ) && checkVarianceOK() then
3356
3356
mods |= Covariant
@@ -4078,6 +4078,14 @@ object Parsers {
4078
4078
val nameStart = in.offset
4079
4079
val name = if isIdent && followingIsGivenSig() then ident() else EmptyTermName
4080
4080
4081
+ // TODO Change syntax description
4082
+ def adjustDefParams (paramss : List [ParamClause ]): List [ParamClause ] =
4083
+ paramss.nestedMap: param =>
4084
+ if ! param.mods.isAllOf(PrivateLocal ) then
4085
+ syntaxError(em " method parameter ${param.name} may not be `a val` " , param.span)
4086
+ param.withMods(param.mods &~ (AccessFlags | ParamAccessor | Mutable ) | Param )
4087
+ .asInstanceOf [List [ParamClause ]]
4088
+
4081
4089
val gdef =
4082
4090
val tparams = typeParamClauseOpt(ParamOwner .Given )
4083
4091
newLineOpt()
@@ -4099,16 +4107,17 @@ object Parsers {
4099
4107
mods1 |= Lazy
4100
4108
ValDef (name, parents.head, subExpr())
4101
4109
else
4102
- DefDef (name, joinParams(tparams, vparamss), parents.head, subExpr())
4110
+ DefDef (name, adjustDefParams( joinParams(tparams, vparamss) ), parents.head, subExpr())
4103
4111
else if (isStatSep || isStatSeqEnd) && parentsIsType then
4104
4112
if name.isEmpty then
4105
4113
syntaxError(em " anonymous given cannot be abstract " )
4106
- DefDef (name, joinParams(tparams, vparamss), parents.head, EmptyTree )
4114
+ DefDef (name, adjustDefParams( joinParams(tparams, vparamss) ), parents.head, EmptyTree )
4107
4115
else
4108
- val tparams1 = tparams.map(tparam => tparam.withMods(tparam.mods | PrivateLocal ))
4109
- val vparamss1 = vparamss.map(_.map(vparam =>
4110
- vparam.withMods(vparam.mods &~ Param | ParamAccessor | Protected )))
4111
- val constr = makeConstructor(tparams1, vparamss1)
4116
+ val vparamss1 = vparamss.nestedMap: vparam =>
4117
+ if vparam.mods.is(Private )
4118
+ then vparam.withMods(vparam.mods &~ PrivateLocal | Protected )
4119
+ else vparam
4120
+ val constr = makeConstructor(tparams, vparamss1)
4112
4121
val templ =
4113
4122
if isStatSep || isStatSeqEnd then Template (constr, parents, Nil , EmptyValDef , Nil )
4114
4123
else withTemplate(constr, parents)
0 commit comments