Implement Generic Mapper<TSource, TDest>


I found this class useful for cutting down repetative MapFrom() methods. I also added a MapInto() method since it is often useful to map value into an existing entity (with proper session usage nHibernate will detect if anything has changed after mapping and if not it will do nothing with .Save is called)
public abstract class Mapper<TSource, TDest> : IMapper<TSource, TDest> {
    public virtual TDest MapFrom(TSource source) {
        return Mapper.Map<TSource, TDest>(source);
    public virtual void MapInto(TSource source, TDest dest) {
        Mapper.Map(source, dest);
When you ViewModel returns data from the user on an Update the MapInto function can be used to make sure that it only saves if changes have been made.
An implemented class of mine looks like this:
public class SecurityRootMapper : Mapper<SecurityRoot, Security>, ISecurityRootMapper {
    public SecurityRootMapper() {
        Mapper.CreateMap<SecurityRoot, Security>()
            .ForMember(x => x.Bond, c => c.Ignore())
            .ForMember(x => x.Prices, c => c.Ignore())
            .ForMember(x => x.Units, c => c.Ignore())
            .ForMember(x => x.Dividend, c => c.Ignore())
            .ForMember(x => x.Id, c => c.Ignore());
This is actually for mapping a message from a proprietary data file format into a domain entity, so no ViewModels are involved but the idea is the same. I use it with nhibernate here:
    public void LoadSecurityData(){
        foreach (var root in _securityRoots.GetEntities()){
            var security = _securityRepository.FindOne(x => x.IBMSecurityNumber == root.IBMSecurityNumber && x.ISIN == root.ISIN) ?? new Security();
If the security exists it will map any fields that are different in the message but the Id remains the same. If it doesn't it just creates a new Security entity first.
Closed Dec 28, 2009 at 11:04 AM by HowardvanRooijen