Skip to content

Not working on Scala >= 3.1.3 #1

@tarao

Description

@tarao

Critical

[error] -- Error: src/main/scala/typing/Typing.scala:30:27 [error] 30 | Typed[subst, Fun[Subst.Ty[subst, Var[Fresh]], t], fresh] [error] | ^ [error] |Match type reduction failed since selector subst [error] |matches none of the cases [error] | [error] | case util.HNil => typing.Var[Fresh] [error] | case typing.Subst[typing.Var[j], t] :+: rest => typing.Var[Fresh] match { [error] | case typing.Var[i] => [error] | i == j match { [error] | case (true : Boolean) => typing.Subst.Ty[rest, t] [error] | case Any => typing.Subst.Ty[rest, typing.Var[Fresh]] [error] | } <: typing.Type [error] | case typing.Fun[s, t] => [error] | typing.Fun[typing.Subst.Ty[subst, s], typing.Subst.Ty[subst, t]] [error] |} <: typing.Type 

Trivial

[error] -- Error: src/main/scala/lambda/DeBruijn.scala:20:28 [error] 20 | HList.Index[v, L] match { [error] | ^ [error] | Match type reduction failed since selector (v, L) [error] | matches none of the cases [error] | [error] | case (i, _) => lambda.DeBruijn.Var[i, v] 
--- a/src/main/scala/lambda/DeBruijn.scala +++ b/src/main/scala/lambda/DeBruijn.scala @@ -18,7 +18,7 @@ object DeBruijn { T match { case lambda.Var[v] => HList.Index[v, L] match { - case (i, _) => Var[i, v] + case (i, Any) => Var[i, v] } case lambda.Abs[v, t] => Abs[v, Transform[t, v :+: L]] case lambda.App[t1, t2] => App[Transform[t1, L], Transform[t2, L]]

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions