I have the following code:
[Test]
public void ConditionalMapping()
{
var src = new Sample1 {Age = 1, Number = null};
var dest = new Sample2 {Age = null, Number = 1};
Hydrate(src, dest, false);
Assert.That(dest.Age, Is.EqualTo(1));
Assert.That(dest.Number, Is.EqualTo(1));
src = new Sample1 {Age = null, Number = 1};
dest = new Sample2 {Age = 1, Number = null};
Hydrate(src, dest, true);
Assert.That(dest.Age, Is.Null);
Assert.That(dest.Number, Is.EqualTo(1));
}
public void Hydrate(Sample1 src, Sample2 dest, bool allowOverride)
{
if (!dest.Age.HasValue || allowOverride)
dest.Age = src.Age;
if (!dest.Number.HasValue || allowOverride)
dest.Number = src.Number;
}
public class Sample1
{
public int? Age { get; set; }
public int? Number { get; set; }
}
public class Sample2
{
public int? Age { get; set; }
public int? Number { get; set; }
}
Which basically hydrates an int?
if the value is null
unless allowOverride = true
, in which it will hydrate the value without checking the value of the field.
How would I go about doing this in Automapper?
I know that you can use .Condition() as shown here:
Automapper's condition gets ignored
But I couldn't figure out how to:
- Apply the logic based on
int?
without defining it one by one. - Include the
allowOverride
boolean to the Mapper.
I may have found a potential solution for you - depending on how you want the
allowOverride
flag to work.If you want the flag to operate the same for all mappings you can create a
TypeConverter
as followsInitialise it like this:
It will now check the destination for a value, and override it as appropriate depending on your constructor argument.
OR
If you want to be able to configure it for each mapping specifically, then you could use a
ValueResolver
(note that this code could do with some extra validation):You can then initialise your mappings like this: