From 2f171973ee8e70250ece98f1fa0890a3db62b848 Mon Sep 17 00:00:00 2001 From: alexshabal Date: Thu, 5 Dec 2024 15:07:47 +0300 Subject: [PATCH] - fixed problem wit optional newtypes (#120) Co-authored-by: Aleksandr Shabalin --- .../cassandra4io/cql/package.scala | 26 +++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/src/main/scala/com/ringcentral/cassandra4io/cql/package.scala b/src/main/scala/com/ringcentral/cassandra4io/cql/package.scala index 0a5f466..837cf77 100644 --- a/src/main/scala/com/ringcentral/cassandra4io/cql/package.scala +++ b/src/main/scala/com/ringcentral/cassandra4io/cql/package.scala @@ -184,9 +184,31 @@ package object cql { override def binder: Binder[RT] = f.binder } - implicit def hConsBindableValuesBuilder[V[_] <: Values[_], T: ColumnsValues, PT <: HList, RT <: HList](implicit + implicit def hConsBindableValuesBuilder[T: ColumnsValues, PT <: HList, RT <: HList](implicit f: BindableBuilder.Aux[PT, RT] - ): BindableBuilder.Aux[V[T] :: PT, T :: RT] = new BindableBuilder[V[T] :: PT] { + ): BindableBuilder.Aux[Values[T] :: PT, T :: RT] = new BindableBuilder[Values[T] :: PT] { + override type Repr = T :: RT + override def binder: Binder[T :: RT] = { + implicit val hBinder: Binder[T] = Values[T].binder + implicit val tBinder: Binder[RT] = f.binder + Binder[T :: RT] + } + } + + implicit def hConsBindableEqualsToBuilder[T: ColumnsValues, PT <: HList, RT <: HList](implicit + f: BindableBuilder.Aux[PT, RT] + ): BindableBuilder.Aux[EqualsTo[T] :: PT, T :: RT] = new BindableBuilder[EqualsTo[T] :: PT] { + override type Repr = T :: RT + override def binder: Binder[T :: RT] = { + implicit val hBinder: Binder[T] = Values[T].binder + implicit val tBinder: Binder[RT] = f.binder + Binder[T :: RT] + } + } + + implicit def hConsBindableAssignmentsBuilder[T: ColumnsValues, PT <: HList, RT <: HList](implicit + f: BindableBuilder.Aux[PT, RT] + ): BindableBuilder.Aux[Assignment[T] :: PT, T :: RT] = new BindableBuilder[Assignment[T] :: PT] { override type Repr = T :: RT override def binder: Binder[T :: RT] = { implicit val hBinder: Binder[T] = Values[T].binder