All mappers of Mappie define mapper variants for collections. Specifically, for List
and Set
. When we want to map a
property of such a type, we do not want to copy the collection itself, but the elements contained in such a type.
Mappie automatically detects if the property is a (nullable) collection, and will automatically select the correct mapping function to be used.
We can also explicitly reference a mapper using the getters forList
and forSet
defined
in each mapper.
For example, suppose we have the data class Book
containing a list of Page
data class Book(val pages: List<Page>)
data class Page(val text: String)
and we have a data class BookDto
containing a list of strings
data class BookDto(val pages: List<String>)
We can define a mapping between Book
and BookDto
by defining two mappers: a mapper for Page
to String
, which simply
gets the text
property, and mapper between Book
and BookDto
using the inner forList
mapper of the PageMapper
object PageMapper : ObjectMappie<Page, String>() {
override fun map(from: Page): String = from.text
}
object BookMapper : ObjectMappie<Book, BookDto>() {
override fun map(from: Book): BookDto = mapping {
BookDto::pages fromProperty Book::pages via PageMapper.forList
}
}
Note that BookMapper
is superfluous and is equivalent to
object BookMapper : ObjectMappie<Book, BookDto>()