From 965a62166493172eb01a248c0ad2b89aa4350ccd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BE=AA?= Date: Sun, 27 Oct 2024 15:09:24 +1300 Subject: [PATCH] save --- syntax/src/main/scala/chester/syntax/core/Term.scala | 3 +++ 1 file changed, 3 insertions(+) diff --git a/syntax/src/main/scala/chester/syntax/core/Term.scala b/syntax/src/main/scala/chester/syntax/core/Term.scala index 08015958..aa7d40b5 100644 --- a/syntax/src/main/scala/chester/syntax/core/Term.scala +++ b/syntax/src/main/scala/chester/syntax/core/Term.scala @@ -23,6 +23,7 @@ case class TermMeta(sourcePos: SourcePos) derives ReadWriter type OptionTermMeta = Option[TermMeta] +@FunctionalInterface trait CallingArgTermF[Rec <: TermT[Rec], ThisTree <: CallingArgTermC[Rec]] { def apply(value: Rec, ty: Rec, name: Option[Name], vararg: Boolean, meta: OptionTermMeta): ThisTree } @@ -63,6 +64,7 @@ case class CallingArgTerm( copy(value = f(value), ty = f(ty)) } +@FunctionalInterface trait CallingF[Rec <: TermT[Rec], ThisTree <: CallingC[Rec]] { def apply(args: Vector[CallingArgTermC[Rec]], implicitly: Boolean, meta: OptionTermMeta): ThisTree } @@ -97,6 +99,7 @@ case class Calling( override def descent(f: Term => Term, g: TreeMap[Term]): Calling = copy(args = args.map(g)) } +@FunctionalInterface trait FCallTermF[Rec <: TermT[Rec], ThisTree <: FCallTermC[Rec]] { def apply(f: Rec, args: Vector[CallingC[Rec]], meta: OptionTermMeta): ThisTree }