Mappie infers implicit mappings by name, type, default arguments, getter- and setter methods, and other mappers that are defined. An implicit mapping for a target property is inferred automatically if it has the same name as a source property, and it is assignable from that source property. If it is not assignable, Mappie will check if there is a single mapper defined that can map the source type to the target type, and will automatically apply it. Mappie comes with several mappers out of the box. See Built-in Mappers.
For example, suppose we have a data class Person
and a data class PersonDto
data class Person(val name: String, val age: Int)
data class PersonDto(val name: String, val age: Int)
The properties of Person
match the parameters of the primary constructor of PersonDto
, and as such, no explicit
mappings have to be defined. We can simply construct such a mapper by writing
object PersonMapper : ObjectMappie<Person, PersonDto>()
which will generate a mapper which calls the primary constructor of PersonDto
assigned to the fields of Person
.
Mapper Generation #
Mappie can also generates mappers automatically. When a source type and a target type do not have an existing mapper, and one can be written without any explicit mappings, it will be generated automatically.
For example, suppose we have the data classes Person
and PersonDto
containing Gender
and GenderDto
enum classes
data class Person(val name: String, val gender: Gender)
enum class Gender { MALE, FEMALE, OTHER; }
data class PersonDto(val name: String, val gender: GenderDto)
enum class GenderDto { MALE, FEMALE, OTHER; }
We can generate a mapper from Person
to PersonDto
by writing
class PersonMapper : ObjectMappie<Person, PersonDto>()
and the nested mapper from Gender
to GenderDto
will be generated automatically as they both contain the same enum
entries.
Note that at this point, this is implemented only for enum classes. Class mappers is work in progress and will be added soon.
Default Arguments #
Mappie also considers default arguments as a possibility.
For example, suppose PersonDto
is defined as
data class PersonDto(
val name: String,
val age: Int,
val hasChildren: Boolean = false,
)
Mappie will use the default argument false
for hasChildren
if no explicit mapping is defined. This is enabled by
default and can be disabled by setting the configuration option useDefaultArguments
to false
.