diff --git a/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelper.cs b/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelper.cs
index 24ec3ae4..3c873594 100644
--- a/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelper.cs
+++ b/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelper.cs
@@ -26,15 +26,18 @@ public CreateConvertFromStrategyHelper(IGenericStrategyProvider
- public TTarget CreateTarget(TSource source, ICollection additionalProcessings)
+ public void Convert(TSource source, TTarget target, ICollection additionalProcessings)
{
- source.NotNull(nameof(source));
- additionalProcessings.NotNull(nameof(additionalProcessings));
+ var strategy = this.strategyProvider.GetStrategy(source);
+ strategy.Convert(source, target, additionalProcessings);
+ }
+ ///
+ public TTarget Create(TSource source)
+ {
var strategy = this.strategyProvider.GetStrategy(source);
var concreteTarget = strategy.CreateTarget(source);
- strategy.Convert(source, concreteTarget, additionalProcessings);
return concreteTarget;
}
diff --git a/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperReverse.cs b/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperReverse.cs
index 853b3048..13278120 100644
--- a/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperReverse.cs
+++ b/src/BBT.StructureTools.Extensions/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperReverse.cs
@@ -30,18 +30,19 @@ public CreateConvertFromStrategyHelperReverse(IGenericStrategyProvider
- public TTarget CreateTarget(
- TSource source,
- TReverseRelation reverseRelation,
- ICollection additionalProcessings)
+ public void Convert(TSource source, TTarget target, ICollection additionalProcessings)
{
- source.NotNull(nameof(source));
- reverseRelation.NotNull(nameof(reverseRelation));
+ var strategy = this.strategyProvider.GetStrategy(source);
+ strategy.Convert(source, target, additionalProcessings);
+ }
+ ///
+ public TTarget Create(TSource source, TReverseRelation reverseRelation)
+ {
var strategy = this.strategyProvider.GetStrategy(source);
var concreteTarget = strategy.CreateTarget(source);
concreteTarget.SetPropertyValue(this.reverseRelationExpr, reverseRelation);
- strategy.Convert(source, concreteTarget, additionalProcessings);
+
return concreteTarget;
}
diff --git a/src/BBT.StructureTools.Extensions/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelper.cs b/src/BBT.StructureTools.Extensions/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelper.cs
index d6968c2e..bdd5b2d8 100644
--- a/src/BBT.StructureTools.Extensions/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelper.cs
+++ b/src/BBT.StructureTools.Extensions/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelper.cs
@@ -47,20 +47,18 @@ public void SetupReverseRelation(Expression> rev
}
///
- public TTarget CreateTarget(
- TSource source,
- TReverseRelation reverseRelation,
- ICollection additionalProcessings)
+ public TTarget Create(TSource source, TReverseRelation reverseRelation)
{
- source.NotNull(nameof(source));
- reverseRelation.NotNull(nameof(reverseRelation));
- additionalProcessings.NotNull(nameof(additionalProcessings));
-
var target = this.instanceCreator.Create();
target.SetPropertyValue(this.reverseRelationExpr, reverseRelation);
- this.convert.Convert(source, target, additionalProcessings);
return target;
}
+
+ ///
+ public void Convert(TSource source, TTarget target, ICollection additionalProcessings)
+ {
+ this.convert.Convert(source, target, additionalProcessings);
+ }
}
///
@@ -92,15 +90,15 @@ public CreateTargetConvertTargetHelper(
}
///
- public TTarget CreateTarget(
- TSource source,
- ICollection additionalProcessings)
+ public void Convert(TSource source, TTarget target, ICollection additionalProcessings)
{
- source.NotNull(nameof(source));
- additionalProcessings.NotNull(nameof(additionalProcessings));
+ this.convert.Convert(source, target, additionalProcessings);
+ }
+ ///
+ public TTarget Create(TSource source)
+ {
var target = this.instanceCreator.Create();
- this.convert.Convert(source, target, additionalProcessings);
return target;
}
}
diff --git a/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelper.cs b/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelper.cs
index 7c7bbf00..d9aac6af 100644
--- a/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelper.cs
+++ b/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelper.cs
@@ -47,20 +47,18 @@ public void SetupReverseRelation(Expression> rev
}
///
- public TTarget CreateTarget(
- TSource source,
- TReverseRelation reverseRelation,
- ICollection additionalProcessings)
+ public TTarget Create(TSource source, TReverseRelation reverseRelation)
{
- source.NotNull(nameof(source));
- reverseRelation.NotNull(nameof(reverseRelation));
- additionalProcessings.NotNull(nameof(additionalProcessings));
-
var target = this.instanceCreator.Create();
target.SetPropertyValue(this.reverseRelationExpr, reverseRelation);
- this.convert.Convert(source, target, additionalProcessings);
return target;
}
+
+ ///
+ public void Convert(TSource source, TTarget target, ICollection additionalProcessings)
+ {
+ this.convert.Convert(source, target, additionalProcessings);
+ }
}
///
@@ -93,15 +91,15 @@ public CreateTargetImplConvertTargetHelper(
}
///
- public TTarget CreateTarget(
- TSource source,
- ICollection additionalProcessings)
+ public void Convert(TSource source, TTarget target, ICollection additionalProcessings)
{
- source.NotNull(nameof(source));
- additionalProcessings.NotNull(nameof(additionalProcessings));
+ this.convert.Convert(source, target, additionalProcessings);
+ }
+ ///
+ public TTarget Create(TSource source)
+ {
var target = this.instanceCreator.Create();
- this.convert.Convert(source, target, additionalProcessings);
return target;
}
}
diff --git a/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelper.cs b/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelper.cs
index 2035a6be..1c2dfe0c 100644
--- a/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelper.cs
+++ b/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelper.cs
@@ -32,15 +32,15 @@ public CreateTargetImplConvertTargetImplHelper(
}
///
- public TTarget CreateTarget(
- TSource source,
- ICollection additionalProcessings)
+ public void Convert(TSource source, TTarget target, ICollection additionalProcessings)
{
- source.NotNull(nameof(source));
- additionalProcessings.NotNull(nameof(additionalProcessings));
+ this.convert.Convert(source, (TTargetImpl)target, additionalProcessings);
+ }
+ ///
+ public TTarget Create(TSource source)
+ {
var target = this.instanceCreator.Create();
- this.convert.Convert(source, target, additionalProcessings);
return target;
}
diff --git a/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperReverse.cs b/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperReverse.cs
index 16e7c890..3e9dcb4f 100644
--- a/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperReverse.cs
+++ b/src/BBT.StructureTools.Extensions/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperReverse.cs
@@ -44,20 +44,19 @@ public void SetupReverseRelation(Expression> rev
}
///
- public TTarget CreateTarget(
- TSource source,
- TReverseRelation reverseRelation,
- ICollection additionalProcessings)
+ public TTarget Create(TSource source, TReverseRelation reverseRelation)
{
- source.NotNull(nameof(source));
- reverseRelation.NotNull(nameof(reverseRelation));
- additionalProcessings.NotNull(nameof(additionalProcessings));
-
var target = this.instanceCreator.Create();
target.SetPropertyValue(this.reverseRelationExpr, reverseRelation);
- this.convert.Convert(source, target, additionalProcessings);
return target;
}
+
+ ///
+ public void Convert(
+ TSource source, TTarget target, ICollection additionalProcessings)
+ {
+ this.convert.Convert(source, (TTargetImpl)target, additionalProcessings);
+ }
}
}
\ No newline at end of file
diff --git a/src/BBT.StructureTools.Tests/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperTests.cs b/src/BBT.StructureTools.Tests/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperTests.cs
index 8f6f2cd9..e7657cae 100644
--- a/src/BBT.StructureTools.Tests/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperTests.cs
+++ b/src/BBT.StructureTools.Tests/Convert/CreateConvertFromStrategy/CreateConvertFromStrategyHelperTests.cs
@@ -34,7 +34,8 @@ public void CreateTarget_NoReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceDerivedLeaf();
- var target = testCandidate.CreateTarget(source, processings);
+ var target = testCandidate.Create(source);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.Should().BeOfType();
@@ -55,7 +56,8 @@ public void CreateTarget_WithReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceDerivedLeaf();
var reverseRelation = new TargetRoot();
- var target = testCandidate.CreateTarget(source, reverseRelation, processings);
+ var target = testCandidate.Create(source, reverseRelation);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.Should().BeOfType();
diff --git a/src/BBT.StructureTools.Tests/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelperTests.cs b/src/BBT.StructureTools.Tests/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelperTests.cs
index 0b7489d0..7ae57416 100644
--- a/src/BBT.StructureTools.Tests/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelperTests.cs
+++ b/src/BBT.StructureTools.Tests/Convert/CreateTargetConvertTarget/CreateTargetConvertTargetHelperTests.cs
@@ -30,7 +30,8 @@ public void CreateTarget_NoReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceTreeLeaf();
- var target = testCandidate.CreateTarget(source, processings);
+ var target = testCandidate.Create(source);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.OriginId.Should().Be(source.Id);
@@ -48,7 +49,8 @@ public void CreateTarget_WithReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceTreeLeaf();
var reverseRelation = new TargetTree();
- var target = testCandidate.CreateTarget(source, reverseRelation, processings);
+ var target = testCandidate.Create(source, reverseRelation);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.OriginId.Should().Be(source.Id);
diff --git a/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelperTests.cs b/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelperTests.cs
index 42f1c3e5..9449fd46 100644
--- a/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelperTests.cs
+++ b/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTarget/CreateTargetImplConvertTargetHelperTests.cs
@@ -30,7 +30,8 @@ public void CreateTarget_NoReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceTreeLeaf();
- var target = testCandidate.CreateTarget(source, processings);
+ var target = testCandidate.Create(source);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.OriginId.Should().Be(source.Id);
@@ -48,7 +49,8 @@ public void CreateTarget_WithReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceTreeLeaf();
var reverseRelation = new TargetTree();
- var target = testCandidate.CreateTarget(source, reverseRelation, processings);
+ var target = testCandidate.Create(source, reverseRelation);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.OriginId.Should().Be(source.Id);
diff --git a/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperTests.cs b/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperTests.cs
index 5de3aa84..3c5b945b 100644
--- a/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperTests.cs
+++ b/src/BBT.StructureTools.Tests/Convert/CreateTargetImplConvertTargetImpl/CreateTargetImplConvertTargetImplHelperTests.cs
@@ -30,7 +30,8 @@ public void CreateTarget_NoReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceTreeLeaf();
- var target = testCandidate.CreateTarget(source, processings);
+ var target = testCandidate.Create(source);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.OriginId.Should().Be(source.Id);
@@ -48,7 +49,8 @@ public void CreateTarget_WithReverseRelation_CreateAndConvert()
var processings = new List();
var source = new SourceTreeLeaf();
var reverseRelation = new TargetTree();
- var target = testCandidate.CreateTarget(source, reverseRelation, processings);
+ var target = testCandidate.Create(source, reverseRelation);
+ testCandidate.Convert(source, target, processings);
target.Should().NotBeNull();
target.OriginId.Should().Be(source.Id);
diff --git a/src/BBT.StructureTools/Convert/ICreateConvertHelper.cs b/src/BBT.StructureTools/Convert/ICreateConvertHelper.cs
index 1e609ee8..3477365c 100644
--- a/src/BBT.StructureTools/Convert/ICreateConvertHelper.cs
+++ b/src/BBT.StructureTools/Convert/ICreateConvertHelper.cs
@@ -23,11 +23,18 @@ public interface ICreateConvertHelper> reverseRelationExpr);
///
- /// Creates a new converted from .
+ /// Creates with .
///
- TTarget CreateTarget(
+ TTarget Create(
TSource source,
- TReverseRelation reverseRelation,
+ TReverseRelation reverseRelation);
+
+ ///
+ /// Converts into .
+ ///
+ void Convert(
+ TSource source,
+ TTarget target,
ICollection additionalProcessings);
}
@@ -43,10 +50,16 @@ public interface ICreateConvertHelper
where TConvertIntention : IBaseConvertIntention
{
///
- /// Creates a new converted from .
+ /// Creates .
+ ///
+ TTarget Create(TSource source);
+
+ ///
+ /// Converts into .
///
- TTarget CreateTarget(
+ void Convert(
TSource source,
+ TTarget target,
ICollection additionalProcessings);
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateFromSourceWithReverseRelation.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateFromSourceWithReverseRelation.cs
index 9f2a147d..aaacb4d1 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateFromSourceWithReverseRelation.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateFromSourceWithReverseRelation.cs
@@ -48,14 +48,16 @@ public void Execute(
return;
}
- var targetValue = this.createConvertHelper.CreateTarget(
- source,
- target,
- additionalProcessings);
+ var targetValue = this.createConvertHelper.Create(source, target);
target.SetPropertyValue(
this.targetExpression,
targetValue);
+
+ this.createConvertHelper.Convert(
+ source,
+ targetValue,
+ additionalProcessings);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToMany.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToMany.cs
index 3b34d6f0..531be5db 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToMany.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToMany.cs
@@ -68,7 +68,7 @@ public void Execute(
var sourceValues = this.sourceFunc.Invoke(source);
- var copies = new List();
+ var targetList = target.GetList(this.targetExpression);
foreach (var sourceValue in sourceValues)
{
@@ -78,15 +78,12 @@ public void Execute(
continue;
}
- var copy = this.createConvertHelper.CreateTarget(
- sourceValue,
- additionalProcessings);
- copies.Add(copy);
- }
+ var copy = this.createConvertHelper.Create(sourceValue);
+
+ targetList.AddUnique(copy);
- target.AddRangeFilterNullValues(
- this.targetExpression,
- copies);
+ this.createConvertHelper.Convert(sourceValue, copy, additionalProcessings);
+ }
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelation.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelation.cs
index 56897688..150dce0e 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelation.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelation.cs
@@ -74,10 +74,9 @@ public void Execute(
var sourceValues = this.sourceFunc.Invoke(source);
- var copies = new List();
-
var relation = this.relationFunc(source, target);
+ var targetList = target.GetList(this.targetExpression);
foreach (var sourceValue in sourceValues)
{
if (!this.convertHelper.ContinueConvertProcess(
@@ -86,16 +85,16 @@ public void Execute(
continue;
}
- var copy = this.createConvertHelper.CreateTarget(
+ var copy = this.createConvertHelper.Create(
+ sourceValue,
+ relation);
+ targetList.AddUnique(copy);
+
+ this.createConvertHelper.Convert(
sourceValue,
- relation,
+ copy,
additionalProcessings);
- copies.Add(copy);
}
-
- target.AddRangeFilterNullValues(
- this.targetExpression,
- copies);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelationInclTargetArg.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelationInclTargetArg.cs
index 5ac3838c..f0e98bf5 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelationInclTargetArg.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithRelationInclTargetArg.cs
@@ -74,10 +74,9 @@ public void Execute(
var sourceValues = this.sourceFunc.Invoke(source, target);
- var copies = new List();
-
var relation = this.relationFunc(source, target);
+ var targetList = target.GetList(this.targetExpression);
foreach (var sourceValue in sourceValues)
{
if (!this.convertHelper.ContinueConvertProcess(
@@ -86,16 +85,17 @@ public void Execute(
continue;
}
- var copy = this.createConvertHelper.CreateTarget(
+ var copy = this.createConvertHelper.Create(
sourceValue,
- relation,
+ relation);
+
+ targetList.AddUnique(copy);
+
+ this.createConvertHelper.Convert(
+ sourceValue,
+ copy,
additionalProcessings);
- copies.Add(copy);
}
-
- target.AddRangeFilterNullValues(
- this.targetExpression,
- copies);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithReverseRelation.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithReverseRelation.cs
index d01fc0d6..89dede21 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithReverseRelation.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToManyWithReverseRelation.cs
@@ -69,8 +69,7 @@ public void Execute(
var sourceValues = this.sourceFunc.Invoke(source);
- var copies = new List();
-
+ var targetList = target.GetList(this.targetExpression);
foreach (var sourceValue in sourceValues)
{
if (!this.convertHelper.ContinueConvertProcess(
@@ -79,16 +78,17 @@ public void Execute(
continue;
}
- var copy = this.createConvertHelper.CreateTarget(
+ var copy = this.createConvertHelper.Create(
+ sourceValue,
+ target);
+
+ targetList.AddUnique(copy);
+
+ this.createConvertHelper.Convert(
sourceValue,
- target,
+ copy,
additionalProcessings);
- copies.Add(copy);
}
-
- target.AddRangeFilterNullValues(
- this.targetExpression,
- copies);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOne.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOne.cs
index ff1fe535..c33ec4e8 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOne.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOne.cs
@@ -60,13 +60,13 @@ public void Execute(
return;
}
- var targetValue = this.createConvertHelper.CreateTarget(
- sourceValue,
- additionalProcessings);
+ var targetValue = this.createConvertHelper.Create(sourceValue);
target.SetPropertyValue(
this.targetExpression,
targetValue);
+
+ this.createConvertHelper.Convert(sourceValue, targetValue, additionalProcessings);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneHistWithCondition.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneHistWithCondition.cs
index 932ec7ef..5cd0bf8a 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneHistWithCondition.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneHistWithCondition.cs
@@ -82,8 +82,7 @@ public void Execute(
var sourceValues = this.sourceFunc.Invoke(source, target);
- var copies = new List();
-
+ var targetList = target.GetList(this.targetExpression);
foreach (var sourceValue in sourceValues)
{
if (!this.convertHelper.ContinueConvertProcess(
@@ -98,21 +97,22 @@ public void Execute(
continue;
}
- var copy = this.createConvertHelper.CreateTarget(
+ var copy = this.createConvertHelper.Create(
sourceValue,
- target,
+ target);
+
+ targetList.AddUnique(copy);
+
+ this.createConvertHelper.Convert(
+ sourceValue,
+ copy,
additionalProcessings);
- copies.Add(copy);
- }
- if (copyToOne)
- {
- this.targetValueTemporalDataHandler.SetEndInfinte(copies[0], TemporalConstants.InfiniteDate);
+ if (copyToOne)
+ {
+ this.targetValueTemporalDataHandler.SetEndInfinte(copy, TemporalConstants.InfiniteDate);
+ }
}
-
- target.AddRangeFilterNullValues(
- this.targetExpression,
- copies);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelation.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelation.cs
index 6d58bb7c..ba486268 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelation.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelation.cs
@@ -67,14 +67,18 @@ public void Execute(
var relation = this.relationFunc(source, target);
- var targetValue = this.createConvertHelper.CreateTarget(
- sourceValue,
- relation,
- additionalProcessings);
+ var targetValue = this.createConvertHelper.Create(
+ sourceValue,
+ relation);
target.SetPropertyValue(
this.targetExpression,
targetValue);
+
+ this.createConvertHelper.Convert(
+ sourceValue,
+ targetValue,
+ additionalProcessings);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelationInclTargetArg.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelationInclTargetArg.cs
index 5a0db366..2900b29c 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelationInclTargetArg.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithRelationInclTargetArg.cs
@@ -67,14 +67,18 @@ public void Execute(
var relation = this.relationFunc(source, target);
- var targetValue = this.createConvertHelper.CreateTarget(
+ var targetValue = this.createConvertHelper.Create(
sourceValue,
- relation,
- additionalProcessings);
+ relation);
target.SetPropertyValue(
this.targetExpression,
targetValue);
+
+ this.createConvertHelper.Convert(
+ sourceValue,
+ targetValue,
+ additionalProcessings);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithReverseRelation.cs b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithReverseRelation.cs
index 8fecea1d..c6230017 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithReverseRelation.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationCreateToOneWithReverseRelation.cs
@@ -60,14 +60,18 @@ public void Execute(
return;
}
- var targetValue = this.createConvertHelper.CreateTarget(
- sourceValue,
- target,
- additionalProcessings);
+ var targetValue = this.createConvertHelper.Create(
+ sourceValue,
+ target);
target.SetPropertyValue(
this.targetExpression,
targetValue);
+
+ this.createConvertHelper.Convert(
+ sourceValue,
+ targetValue,
+ additionalProcessings);
}
}
}
diff --git a/src/BBT.StructureTools/Convert/Strategy/OperationMergeLevel.cs b/src/BBT.StructureTools/Convert/Strategy/OperationMergeLevel.cs
index 25b2d944..204cb748 100644
--- a/src/BBT.StructureTools/Convert/Strategy/OperationMergeLevel.cs
+++ b/src/BBT.StructureTools/Convert/Strategy/OperationMergeLevel.cs
@@ -77,8 +77,6 @@ public void Execute(
var mergeValues = this.mergeFunc.Invoke(source);
- var copies = new List();
-
foreach (var mergeValue in mergeValues)
{
if (!this.convertHelper.ContinueConvertProcess(
@@ -89,6 +87,7 @@ public void Execute(
var sourceValues = this.sourceFunc.Invoke(mergeValue);
+ var targetList = target.GetList(this.targetExpression);
foreach (var sourceValue in sourceValues)
{
if (!this.convertHelper.ContinueConvertProcess(
@@ -97,17 +96,18 @@ public void Execute(
continue;
}
- var copy = this.createConvertHelper.CreateTarget(
+ var copy = this.createConvertHelper.Create(
sourceValue,
- target,
+ target);
+
+ targetList.AddUnique(copy);
+
+ this.createConvertHelper.Convert(
+ sourceValue,
+ copy,
additionalProcessings);
- copies.Add(copy);
}
}
-
- target.AddRangeFilterNullValues(
- this.targetExpression,
- copies);
}
}
}
diff --git a/src/BBT.StructureTools/Extension/ReferenceTypeExtension.cs b/src/BBT.StructureTools/Extension/ReferenceTypeExtension.cs
index b400a378..6d3fc9ce 100644
--- a/src/BBT.StructureTools/Extension/ReferenceTypeExtension.cs
+++ b/src/BBT.StructureTools/Extension/ReferenceTypeExtension.cs
@@ -11,6 +11,45 @@
///
internal static class ReferenceTypeExtension
{
+ ///
+ /// Adds to .
+ /// But only if is not already added.
+ ///
+ /// Type of list entries.
+ internal static void AddUnique(
+ this ICollection targetList,
+ TValue value)
+ where TValue : class
+ {
+ targetList.NotNull(nameof(targetList));
+ value.NotNull(nameof(value));
+
+ if (!targetList.Contains(value))
+ {
+ targetList.Add(value);
+ }
+ }
+
+ ///
+ /// Gets the list of collection property
+ /// according to .
+ ///
+ /// The owner of the list.
+ /// The type of list entries.
+ internal static ICollection GetList(
+ this TTarget target,
+ Expression>> targetExpression)
+ where TTarget : class
+ where TValue : class
+ {
+ target.NotNull(nameof(target));
+ targetExpression.NotNull(nameof(targetExpression));
+
+ var targetListFunc = targetExpression.Compile();
+ var targetList = targetListFunc.Invoke(target);
+ return targetList;
+ }
+
///
/// An extension enabling addition of many elements to an enumeration without adding null values within the origin.
///