supporting equality comparer :)
This commit is contained in:
		
							parent
							
								
									165cc15d0a
								
							
						
					
					
						commit
						9dd5d59b85
					
				| @ -8,10 +8,22 @@ using PoweredSoft.DynamicLinq; | ||||
| 
 | ||||
| namespace PoweredSoft.DynamicLinq.Test | ||||
| { | ||||
|     internal class TestStructure | ||||
|     internal class TestStructureCompare : IEqualityComparer<TestStructure>  | ||||
|     { | ||||
|         public long ClientId { get; set; } | ||||
|         public decimal B { get; set; } | ||||
|         public bool Equals(TestStructure x, TestStructure y) | ||||
|         { | ||||
|             return x?.ClientId == y?.ClientId; | ||||
|         } | ||||
| 
 | ||||
|         public int GetHashCode(TestStructure obj) | ||||
|         { | ||||
|             return obj.ClientId; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     internal class TestStructure  | ||||
|     { | ||||
|         public int ClientId { get; set; } | ||||
|     } | ||||
| 
 | ||||
|     [TestClass] | ||||
| @ -42,7 +54,22 @@ namespace PoweredSoft.DynamicLinq.Test | ||||
| 
 | ||||
|             var dynamicSyntax3 = TestData.Sales | ||||
|                 .AsQueryable() | ||||
|                 .GroupBy(t => t.UseType(typeof(TestStructure)).Path("ClientId").Path("NetSales", "B")); | ||||
|                 .GroupBy(t => t.UseType(typeof(TestStructure)).EqualityComparer(typeof(TestStructureCompare)).Path("ClientId")); | ||||
| 
 | ||||
|             var tryAs = dynamicSyntax3 as EnumerableQuery<IGrouping<TestStructure, MockSale>>; | ||||
|             var list = tryAs.Select(t => new | ||||
|             { | ||||
|                 Key = t.Key, | ||||
|                 Data = t.ToList() | ||||
|             }).ToList(); | ||||
| 
 | ||||
|             var list2 = TestData.Sales.GroupBy(t => new TestStructure { ClientId = t.ClientId }, new TestStructureCompare()).Select(t => new | ||||
|             { | ||||
|                 Key = t.Key, | ||||
|                 Data = t.ToList() | ||||
|             }).ToList(); | ||||
| 
 | ||||
|             int i = 0; | ||||
| 
 | ||||
| 
 | ||||
|             /* | ||||
| @ -57,8 +84,6 @@ namespace PoweredSoft.DynamicLinq.Test | ||||
|                 Sales = t.ToList() | ||||
|             });*/ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|             /* | ||||
|             .Select(t => | ||||
|             { | ||||
| @ -72,5 +97,10 @@ namespace PoweredSoft.DynamicLinq.Test | ||||
|                 t.ToList("Sales"); | ||||
|             });*/ | ||||
|         } | ||||
| 
 | ||||
|         private object compare(MockSale arg) | ||||
|         { | ||||
|             throw new NotImplementedException(); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -19,7 +19,7 @@ namespace PoweredSoft.DynamicLinq.Test | ||||
|     internal class MockSale | ||||
|     { | ||||
|         public long Id { get; set; } | ||||
|         public long ClientId { get; set; } | ||||
|         public int ClientId { get; set; } | ||||
|         public MockClient Client { get; set; } | ||||
|         public decimal GrossSales { get; set; } | ||||
|         public decimal NetSales { get; set; } | ||||
|  | ||||
| @ -44,6 +44,7 @@ namespace PoweredSoft.DynamicLinq | ||||
|     internal static class Constants | ||||
|     { | ||||
|         internal static readonly MethodInfo GroupByMethod = typeof(Queryable).GetMethods().First(t => t.Name == "GroupBy"); | ||||
|         internal static readonly MethodInfo GroupByMethodWithEqualityComparer = typeof(Queryable).GetMethods().First(t => t.Name == "GroupBy" && t.GetParameters().Any(t2 => t2.Name == "comparer")); | ||||
|         internal static readonly MethodInfo StringEqualWithComparisation = typeof(string).GetMethod("Equals", new Type[] { typeof(string), typeof(StringComparison) }); | ||||
|         internal static readonly MethodInfo ContainsMethod = typeof(string).GetMethod("Contains"); | ||||
|         internal static readonly MethodInfo StartsWithMethod = typeof(string).GetMethod("StartsWith", new Type[] { typeof(string) }); | ||||
|  | ||||
| @ -86,7 +86,7 @@ namespace PoweredSoft.DynamicLinq | ||||
|             if (groupBuilder.Empty) | ||||
|                 throw new Exception("No group specified, please specify at least one group"); | ||||
| 
 | ||||
|             return QueryableHelpers.GroupBy(query, type, groupBuilder.Parts, groupBuilder.Type); | ||||
|             return QueryableHelpers.GroupBy(query, type, groupBuilder.Parts, groupBuilder.Type, groupBuilder.EqualityComparerType); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -10,6 +10,7 @@ namespace PoweredSoft.DynamicLinq.Fluent | ||||
|         public List<(string path, string propertyName)> Parts { get; set; } = new List<(string path, string propertyName)>(); | ||||
|         public Type Type { get; set; } | ||||
|         public bool Empty => !Parts.Any(); | ||||
|         public Type EqualityComparerType { get; set; } | ||||
| 
 | ||||
|         public GroupBuilder Path(string path, string propertyName = null) | ||||
|         { | ||||
| @ -37,5 +38,11 @@ namespace PoweredSoft.DynamicLinq.Fluent | ||||
|             Type = type; | ||||
|             return this; | ||||
|         } | ||||
| 
 | ||||
|         public GroupBuilder EqualityComparer(Type type) | ||||
|         { | ||||
|             EqualityComparerType = type; | ||||
|             return this; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -77,7 +77,7 @@ namespace PoweredSoft.DynamicLinq.Helpers | ||||
|             return ret;             | ||||
|         } | ||||
| 
 | ||||
|         public static IQueryable GroupBy(IQueryable query, Type type, List<(string path, string propertyName)> parts, Type groupToType = null) | ||||
|         public static IQueryable GroupBy(IQueryable query, Type type, List<(string path, string propertyName)> parts, Type groupToType = null, Type equalityCompareType = null) | ||||
|         { | ||||
|             // EXPRESSION | ||||
|             var parameter = Expression.Parameter(type, "t"); | ||||
| @ -93,8 +93,7 @@ namespace PoweredSoft.DynamicLinq.Helpers | ||||
|                 partExpressions.Add((partExpression, part.propertyName)); | ||||
|             }); | ||||
| 
 | ||||
|             var anonymousType = groupToType ?? TypeHelpers.CreateSimpleAnonymousType(fields); | ||||
| 
 | ||||
|             var keyType = groupToType ?? TypeHelpers.CreateSimpleAnonymousType(fields); | ||||
| 
 | ||||
|             /* | ||||
|             var constructorTypes = fields.Select(t => t.type).ToArray(); | ||||
| @ -105,12 +104,12 @@ namespace PoweredSoft.DynamicLinq.Helpers | ||||
|             var groupByExpression = Expression.Call(genericMethod, query.Expression, lambda); | ||||
|             var result = query.Provider.CreateQuery(groupByExpression);*/ | ||||
| 
 | ||||
|             var ctor = Expression.New(anonymousType); | ||||
|             var bindings = partExpressions.Select(partExpression => Expression.Bind(anonymousType.GetProperty(partExpression.propertyName), partExpression.expression)).ToList(); | ||||
|             var ctor = Expression.New(keyType); | ||||
|             var bindings = partExpressions.Select(partExpression => Expression.Bind(keyType.GetProperty(partExpression.propertyName), partExpression.expression)).ToList(); | ||||
|             var mi = Expression.MemberInit(ctor, bindings.ToArray()); | ||||
|             var lambda = Expression.Lambda(mi, parameter); | ||||
|             var genericMethod = Constants.GroupByMethod.MakeGenericMethod(type, anonymousType); | ||||
|             var groupByExpression = Expression.Call(genericMethod, query.Expression, lambda); | ||||
|             var genericMethod = equalityCompareType == null ? Constants.GroupByMethod.MakeGenericMethod(type, keyType) : Constants.GroupByMethodWithEqualityComparer.MakeGenericMethod(type, keyType); //, Activator.CreateInstance(equalityCompareType)); | ||||
|             var groupByExpression = equalityCompareType == null ? Expression.Call(genericMethod, query.Expression, lambda) : Expression.Call(genericMethod, query.Expression, lambda, Expression.New(equalityCompareType)); | ||||
|             var result = query.Provider.CreateQuery(groupByExpression); | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user