This is really just a specific form of combining two Expression<Func<T, T>>
values. Here's an example of doing that:
using System;
using System.Linq.Expressions;
public class Test
{
public static Expression<Func<T, T>> Apply<T>
(Expression<Func<T, T>> first, Expression<Func<T, T>> second)
{
ParameterExpression input = Expression.Parameter(typeof(T), "input");
Expression invokedSecond = Expression.Invoke(second,
new Expression[]{input});
Expression invokedFirst = Expression.Invoke(first,
new[]{invokedSecond});
return Expression.Lambda<Func<T, T>>(invokedFirst, new[]{input});
}
static void Main()
{
var addAndSquare = Apply<int>(x => x + 1,
x => x * x);
Console.WriteLine(addAndSquare.Compile()(5));
}
}
You could write ApplySequence
in those terms easily, if you wanted to:
public static Expression<Func<IEnumerable<T>, IEnumerable<T>>>
ApplySequence<T>
(Expression<Func<IEnumerable<T>, IEnumerable<T>>> first,
Expression<Func<IEnumerable<T>, IEnumerable<T>>> second)
{
return Apply(first, second);
}