public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, bool inMemory, out Expression expression) { if (operation.Kind == FilterOperationKind.ArrayAny && type.IsInstanceOfType(value) && type.ParseLiteral(value) is bool parsedValue) { MemberExpression property = Expression.Property(instance, operation.Property); Type propertType = operation.Type; if (operation.TryGetSimpleFilterBaseType(out Type baseType)) { propertType = baseType; } if (parsedValue) { expression = FilterExpressionBuilder.Any( propertType, property); } else { expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.Any( propertType, property)); } if (inMemory) { expression = FilterExpressionBuilder.NotNullAndAlso(property, expression); } return(true); } expression = null; return(false); }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, IQueryableFilterVisitorContext context, [NotNullWhen(true)] out Expression?expression) { if (operation.Kind == FilterOperationKind.ArrayAny && type.IsInstanceOfType(value) && context.InputParser.ParseLiteral(value, type) is bool parsedValue) { MemberExpression property = Expression.Property(context.GetInstance(), operation.Property); Type propertyType = operation.Type; if (operation.TryGetSimpleFilterBaseType(out Type? baseType)) { propertyType = baseType; } if (parsedValue) { expression = FilterExpressionBuilder.Any( propertyType, property); } else { expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.Any( propertyType, property)); } if (context.InMemory) { expression = FilterExpressionBuilder.NotNullAndAlso(property, expression); } return(true); } expression = null; return(false); }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, IQueryableFilterVisitorContext context, [NotNullWhen(true)] out Expression?expression) { if (operation.Type == typeof(string) && type.IsInstanceOfType(value)) { Expression property = context.GetInstance(); if (!operation.IsSimpleArrayType()) { property = Expression.Property( context.GetInstance(), operation.Property); } object?parsedValue = type.ParseLiteral(value); if (operation.Kind == FilterOperationKind.In) { expression = FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue); return(true); } if (operation.Kind == FilterOperationKind.NotIn) { expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue)); return(true); } } expression = null; return(false); }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, bool inMemory, out Expression expression) { if (operation.Type == typeof(string) && type.IsInstanceOfType(value)) { Expression property = instance; if (!operation.IsSimpleArrayType()) { property = Expression.Property(instance, operation.Property); } var parsedValue = type.ParseLiteral(value); switch (operation.Kind) { case FilterOperationKind.In: expression = FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue); return(true); case FilterOperationKind.NotIn: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue)); return(true); } } expression = null; return(false); }
public static bool Enter( FilterOperationField field, ObjectFieldNode node, IQueryableFilterVisitorContext context, [NotNullWhen(true)] out ISyntaxVisitorAction?action) { if (node.Value.IsNull()) { if (field.Operation.IsNullable) { MemberExpression nestedProperty = Expression.Property( context.GetInstance(), field.Operation.Property); Expression expression = FilterExpressionBuilder.Equals(nestedProperty, null !); context.GetLevel().Enqueue(expression); } else { context.ReportError( ErrorHelper.CreateNonNullError(field, node, context)); } action = SyntaxVisitor.Skip; return(true); } if (field.Operation.Kind == FilterOperationKind.Object) { MemberExpression nestedProperty = Expression.Property( context.GetInstance(), field.Operation.Property); context.PushInstance(nestedProperty); action = SyntaxVisitor.Continue; return(true); } action = null; return(false); }
public void Leave( FilterOperationField field, ObjectFieldNode node, ISyntaxNode parent, IReadOnlyList <object> path, IReadOnlyList <ISyntaxNode> ancestors, Stack <QueryableClosure> closures) { if (field.Operation.Kind == FilterOperationKind.Object) { // Deque last expression to prefix with nullcheck Expression condition = closures.Peek().Level.Peek().Dequeue(); Expression property = closures.Peek().Instance.Peek(); // wrap last expression closures.Peek().Level.Peek().Enqueue( FilterExpressionBuilder.NotNullAndAlso( property, condition)); closures.Peek().Instance.Pop(); } }
public static void Leave( FilterOperationField field, ObjectFieldNode node, IQueryableFilterVisitorContext context) { if (field.Operation.Kind == FilterOperationKind.Object) { // Deque last expression to prefix with nullcheck Expression condition = context.GetLevel().Dequeue(); Expression property = context.GetInstance(); // wrap last expression only if in memory if (context.InMemory) { condition = FilterExpressionBuilder.NotNullAndAlso( property, condition); } context.GetLevel().Enqueue(condition); context.PopInstance(); } }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, out Expression expression) { if (operation.Type == typeof(IComparable) && value is ListValueNode li) { MemberExpression property = Expression.Property(instance, operation.Property); var parsedValue = type.ParseLiteral(value); switch (operation.Kind) { case FilterOperationKind.In: expression = FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue); return(true); case FilterOperationKind.NotIn: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue) ); return(true); } } expression = null; return(false); }
public static bool NotEquals( FilterOperation operation, IInputType type, IValueNode value, IQueryableFilterVisitorContext context, [NotNullWhen(true)] out Expression?result) { object parsedValue = type.ParseLiteral(value); if (parsedValue == null) { context.ReportError( ErrorHelper.CreateNonNullError(operation, type, value, context)); result = null; return(false); } if (operation.Type == typeof(bool) && type.IsInstanceOfType(value) && parsedValue is bool) { Expression property = context.GetInstance(); if (!operation.IsSimpleArrayType()) { property = Expression.Property(context.GetInstance(), operation.Property); } result = FilterExpressionBuilder.NotEquals(property, parsedValue); return(true); } else { throw new InvalidOperationException(); } }
protected override bool TryCreateExpression( FilterOperation operation, Expression property, object parsedValue, [NotNullWhen(true)] out Expression?expression) { switch (operation.Kind) { case FilterOperationKind.Contains: expression = FilterExpressionBuilder.Contains( property, parsedValue); return(true); case FilterOperationKind.NotContains: expression = FilterExpressionBuilder.NotContains( property, parsedValue); return(true); default: expression = null; return(false); } }
protected override bool TryCreateExpression( FilterOperation operation, Expression property, Func <object> parseValue, out Expression expression) { switch (operation.Kind) { case FilterOperationKind.Equals: expression = FilterExpressionBuilder.Equals( property, parseValue()); return(true); case FilterOperationKind.NotEquals: expression = FilterExpressionBuilder.NotEquals( property, parseValue()); return(true); default: expression = null; return(false); } }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, out Expression expression) { if (operation.Kind == FilterOperationKind.ArrayAny && type.IsInstanceOfType(value) && type.ParseLiteral(value) is bool parsedValue) { Expression property = instance; if (!operation.IsSimpleArrayType()) { property = Expression.Property(instance, operation.Property); } if (parsedValue) { expression = FilterExpressionBuilder.Any( operation.Type, property); } else { expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.Any( operation.Type, property)); } return(true); } expression = null; return(false); }
protected override bool TryCreateExpression( FilterOperation operation, MemberExpression property, object parsedValue, out Expression expression) { switch (operation.Kind) { case FilterOperationKind.LowerThan: expression = FilterExpressionBuilder.LowerThan( property, parsedValue); return(true); case FilterOperationKind.NotLowerThan: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.LowerThan( property, parsedValue)); return(true); default: expression = null; return(false); } }
public static bool NotIn( FilterOperation operation, IInputType type, IValueNode value, IQueryableFilterVisitorContext context, [NotNullWhen(true)] out Expression?result) { object parsedValue = type.ParseLiteral(value); if (parsedValue == null) { context.ReportError( ErrorHelper.CreateNonNullError(operation, type, value, context)); result = null; return(false); } if (operation.Type == typeof(IComparable) && type.IsInstanceOfType(value)) { Expression property = GetProperty(operation, context); parsedValue = ParseValue(parsedValue, operation, type, context); result = FilterExpressionBuilder.Not( FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue)); return(true); } else { throw new InvalidOperationException(); } }
protected override bool TryCreateExpression( FilterOperation operation, Expression property, Func <object> parseValue, [NotNullWhen(true)] out Expression?expression) { switch (operation.Kind) { case FilterOperationKind.GreaterThanOrEquals: expression = FilterExpressionBuilder.GreaterThanOrEqual( property, parseValue()); return(true); case FilterOperationKind.NotGreaterThanOrEquals: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.GreaterThanOrEqual( property, parseValue())); return(true); default: expression = null; return(false); } }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, out Expression expression) { if (operation.Type == typeof(bool) && type.IsInstanceOfType(value)) { Expression property = instance; if (!operation.IsSimpleArrayType()) { property = Expression.Property(instance, operation.Property); } object parserValue = type.ParseLiteral(value); switch (operation.Kind) { case FilterOperationKind.Equals: expression = FilterExpressionBuilder.Equals( property, parserValue); return(true); case FilterOperationKind.NotEquals: expression = FilterExpressionBuilder.NotEquals( property, parserValue); return(true); } } expression = null; return(false); }
public static bool ArrayAny( FilterOperation operation, IInputType type, IValueNode value, IQueryableFilterVisitorContext context, [NotNullWhen(true)] out Expression?result) { object parsedValue = type.ParseLiteral(value); if (parsedValue == null) { context.ReportError( ErrorHelper.CreateNonNullError(operation, type, value, context)); result = null; return(false); } if (operation.Kind == FilterOperationKind.ArrayAny && type.IsInstanceOfType(value) && parsedValue is bool parsedBool) { MemberExpression property = Expression.Property(context.GetInstance(), operation.Property); Type propertType = operation.Type; if (operation.TryGetSimpleFilterBaseType(out Type? baseType)) { propertType = baseType; } Expression expression; if (parsedBool) { expression = FilterExpressionBuilder.Any( propertType, property); } else { expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.Any( propertType, property)); } if (context.InMemory) { expression = FilterExpressionBuilder.NotNullAndAlso(property, expression); } result = expression; return(true); } else { throw new InvalidOperationException(); } }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, out Expression expression) { if (operation.Type == typeof(IComparable) && type.IsInstanceOfType(value)) { Expression property = instance; if (!operation.IsSimpleArrayType()) { property = Expression.Property(instance, operation.Property); } switch (operation.Kind) { case FilterOperationKind.In: expression = FilterExpressionBuilder.In( property, operation.Property.PropertyType, ParseValue()); return(true); case FilterOperationKind.NotIn: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.In( property, operation.Property.PropertyType, ParseValue()) ); return(true); } } expression = null; return(false); object ParseValue() { var parsedValue = type.ParseLiteral(value); Type elementType = type.ElementType().ToClrType(); if (operation.Property.PropertyType != elementType) { Type listType = typeof(List <>).MakeGenericType( operation.Property.PropertyType); parsedValue = converter.Convert( typeof(object), listType, parsedValue); } return(parsedValue); } }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, out Expression expression) { if (operation.Type == typeof(IComparable) && value is IValueNode <IComparable> s) { MemberExpression property = Expression.Property(instance, operation.Property); var parsedValue = type.ParseLiteral(value); if (operation.Property.PropertyType .IsInstanceOfType(parsedValue)) { parsedValue = converter.Convert( typeof(object), operation.Property.PropertyType, parsedValue); } switch (operation.Kind) { case FilterOperationKind.Equals: expression = FilterExpressionBuilder.Equals( property, parsedValue); return(true); case FilterOperationKind.NotEquals: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.Equals( property, parsedValue) ); return(true); case FilterOperationKind.GreaterThan: expression = FilterExpressionBuilder.GreaterThan( property, parsedValue); return(true); case FilterOperationKind.NotGreaterThan: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.GreaterThan( property, parsedValue) ); return(true); case FilterOperationKind.GreaterThanOrEqual: expression = FilterExpressionBuilder.GreaterThanOrEqual( property, parsedValue); return(true); case FilterOperationKind.NotGreaterThanOrEqual: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.GreaterThanOrEqual( property, parsedValue) ); return(true); case FilterOperationKind.LowerThan: expression = FilterExpressionBuilder.LowerThan( property, parsedValue); return(true); case FilterOperationKind.NotLowerThan: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.LowerThan( property, parsedValue)); return(true); case FilterOperationKind.LowerThanOrEqual: expression = FilterExpressionBuilder.LowerThanOrEqual( property, parsedValue); return(true); case FilterOperationKind.NotLowerThanOrEqual: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.LowerThanOrEqual( property, parsedValue)); return(true); } } if (operation.Type == typeof(IComparable) && value is ListValueNode li) { MemberExpression property = Expression.Property(instance, operation.Property); var parsedValue = type.ParseLiteral(value); switch (operation.Kind) { case FilterOperationKind.In: expression = FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue); return(true); case FilterOperationKind.NotIn: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue) ); return(true); } } expression = null; return(false); }
public bool TryHandle( FilterOperation operation, IInputType type, IValueNode value, Expression instance, ITypeConversion converter, out Expression expression) { if (operation.Type == typeof(string) && value is StringValueNode s) { MemberExpression property = Expression.Property(instance, operation.Property); switch (operation.Kind) { case FilterOperationKind.Equals: expression = FilterExpressionBuilder.Equals( property, s.Value); return(true); case FilterOperationKind.NotEquals: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.Equals(property, s.Value) ); return(true); case FilterOperationKind.StartsWith: expression = FilterExpressionBuilder.StartsWith( property, s.Value); return(true); case FilterOperationKind.EndsWith: expression = FilterExpressionBuilder.EndsWith( property, s.Value); return(true); case FilterOperationKind.NotStartsWith: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.StartsWith( property, s.Value) ); return(true); case FilterOperationKind.NotEndsWith: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.EndsWith(property, s.Value) ); return(true); case FilterOperationKind.Contains: expression = FilterExpressionBuilder.Contains( property, s.Value); return(true); case FilterOperationKind.NotContains: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.Contains(property, s.Value) ); return(true); } } if (operation.Type == typeof(string) && value is ListValueNode li) { MemberExpression property = Expression.Property(instance, operation.Property); var parsedValue = type.ParseLiteral(value); switch (operation.Kind) { case FilterOperationKind.In: expression = FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue); return(true); case FilterOperationKind.NotIn: expression = FilterExpressionBuilder.Not( FilterExpressionBuilder.In( property, operation.Property.PropertyType, parsedValue)); return(true); } } expression = null; return(false); }