Вопрос

Я хотел бы создать выражение, которое будет соответствовать ожидаемому ...

Expression<Func<ReferencedEntity, bool>> expected = (ReferencedEntity referencedEntity) => foreignKeys.Contains(referencedEntity.Id);
Expression<Func<ReferencedEntity, bool>> actual;

тип foreignKeys - это List < object >

Вот что у меня есть, и я думаю, что он будет использовать метод Expression.Call (), но не уверен, как именно это сделать.

ParameterExpression entityParameter = Expression.Parameter(typeof(TReferencedEntity), "referencedEntity");
MemberExpression memberExpression = Expression.Property(entityParameter, "Id");
Expression convertExpression = Expression.Convert(memberExpression, typeof(object)); //This is becuase the memberExpression for Id returns a int.

//Expression containsExpression = Expression.Call(????

//actual = Expression.Lambda<Func<TReferencedEntity, bool>>(????, entityParameter);

Спасибо за помощь.

Это было полезно?

Решение

Вот решение, которое я не смог бы сделать без предложения Самуила, хотя ...

    /// <summary>
    /// 
    /// </summary>
    /// <param name="foreignKeys"></param>
    /// <returns></returns>
    private Expression<Func<TReferencedEntity, bool>> BuildForeignKeysContainsPredicate(List<object> foreignKeys, string primaryKey)
    {
        Expression<Func<TReferencedEntity, bool>> result = default(Expression<Func<TReferencedEntity, bool>>);

        try
        {
            ParameterExpression entityParameter = Expression.Parameter(typeof(TReferencedEntity), "referencedEntity");
            ConstantExpression foreignKeysParameter = Expression.Constant(foreignKeys, typeof(List<object>));
            MemberExpression memberExpression = Expression.Property(entityParameter, primaryKey);
            Expression convertExpression = Expression.Convert(memberExpression, typeof(object));
            MethodCallExpression containsExpression = Expression.Call(foreignKeysParameter
                , "Contains", new Type[] { }, convertExpression);

            result = Expression.Lambda<Func<TReferencedEntity, bool>>(containsExpression, entityParameter);

        }
        catch (Exception ex)
        {
            throw ex;
        }

        return result;
    }

Другие советы

Я не знаю решения, но я знаю, как вы могли бы его получить. Создайте фиктивную функцию, которая принимает выражение Expression < Func < ReferencedEntity, bool > > > > > > > > > > > > > > > > > ; А с помощью отладчика вы можете проверить, как компилятор создал для вас выражение.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top