I have this situation (stripped down to the essential parts)
class Foo[L <: HList](columns: L) {
class toRecord(row: Row) extends Poly1 {
implicit def caseColumn[T] = at[Column[T]] { /* map to a record field */ }
}
def asRecord = {
val resultSet: Stream[Row] = // computation to get result set
resultSet.map { row =>
val m = new toRecord(row) // this can't work
columns.map(m)
}
}
}
This doesn't work since map
wants a stable identifier and m
is not.
So I would need as many Poly1 singleton objects
as many rows I have in the result set.
This is the same problem discussed here: https://groups.google.com/forum/#!topic/shapeless-dev/P5DXRgnzqkY, but I can't find a way of making this work.
In the linked discussion Miles Sabin proposed a fold
with a Poly2
instead of a map
with a Poly1
, but I can't figure how to use this suggestion in my case.
Ok, I finally managed to use a
Poly2
with afoldRight
in order to simulate a parametric map.Here's an example to get the idea
So the "trick" here is to pass the parameter as the initial value of the fold and carry it along during the computation.
Inside the computation we apply a transformation on each element using
row
as parameter (our "parametric mapping") and then we simply append it to the accumulator.When we're done, we end up with a tuple containing
row
and the mappedHList
: we can simply discard the former (._2
) and we're good to go.