1
Ich versuche, caseclassmerge Beispiel von Shapeless-Bibliothek zu ändern, nur Nicht-Null-Felder zusammenzuführen.Nicht-Null-Felder in zwei Fallklassen zusammenführen
object mergeSyntax {
implicit class MergeSyntax[T](t: T) {
def merge[U](u: U)(implicit merge: CaseClassMerge[T, U]): T = merge(t, u)
}
}
trait CaseClassMerge[T, U] {
def apply(t: T, u: U): T
}
object CaseClassMerge {
import ops.record.Merger
def apply[T, U](implicit merge: CaseClassMerge[T, U]): CaseClassMerge[T, U] = merge
implicit def mkCCMerge[T, U, RT <: HList, RU <: HList]
(implicit
tgen: LabelledGeneric.Aux[T, RT],
ugen: LabelledGeneric.Aux[U, RU],
merger: Merger.Aux[RT, RU, RT]
): CaseClassMerge[T, U] =
new CaseClassMerge[T, U] {
def apply(t: T, u: U): T =
tgen.from(merger(tgen.to(t), ugen.to(u)))
}
}
Wie die Verbindungslogik in einer Art und Weise zu ändern, dass nur Nicht-Null-Felder im zweiten Argumente werden in das erste Argument zusammengeführt werden?