Skip to content

Commit

Permalink
feat: Add compile-time Head
Browse files Browse the repository at this point in the history
  • Loading branch information
Iltotore committed Sep 20, 2024
1 parent bbe7ce6 commit 9c54fa3
Showing 1 changed file with 13 additions and 1 deletion.
14 changes: 13 additions & 1 deletion main/src/io/github/iltotore/iron/constraint/collection.scala
Original file line number Diff line number Diff line change
Expand Up @@ -356,7 +356,7 @@ object collection:

class HeadIterable[A, I <: Iterable[A], C, Impl <: Constraint[A, C]](using Impl) extends Constraint[I, Head[C]]:

override inline def test(inline value: I): Boolean = value.headOption.exists(summonInline[Impl].test(_))
override inline def test(inline value: I): Boolean = ${ checkIterable('value, '{ summonInline[Impl] }) }

override inline def message: String = "Head: (" + summonInline[Impl].message + ")"

Expand All @@ -371,6 +371,18 @@ object collection:

inline given headString[C, Impl <: Constraint[Char, C]](using inline impl: Impl): HeadString[C, Impl] = new HeadString

private def checkIterable[A : Type, I <: Iterable[A] : Type, C, Impl <: Constraint[A, C]](expr: Expr[I], constraintExpr: Expr[Impl])(using Quotes): Expr[Boolean] =
val rflUtil = reflectUtil
import rflUtil.*

expr.toExprList match
case Some(list) =>
list.headOption match
case Some(head) => applyConstraint(list.head, constraintExpr)
case None => Expr(false)

case None => '{ $expr.exists(c => ${ applyConstraint('c, constraintExpr) }) }

private def checkString[C, Impl <: Constraint[Char, C]](expr: Expr[String], constraintExpr: Expr[Impl])(using Quotes): Expr[Boolean] =
val rflUtil = reflectUtil
import rflUtil.*
Expand Down

0 comments on commit 9c54fa3

Please sign in to comment.