TPL Dataflow provides a TransformBlock for transforming input, e.g.:
var tb = new TransformBlock<int, int>(i => i * 2);
Is it possible to not output some of the input, e.g. if the input fails some validation test?
var tb = new TransformBlock<InputType, OutputType>(i =>
{
if (!ValidateInput(i))
{
// Do something to not output anything for this input
}
// Normal output
}
If that is not possible, what would be the best pattern to achieve that end?
Something like the following?
BufferBlock<OutputType> output = new BufferBlock<OutputType>();
var ab = new ActionBlock<InputType>(i =>
{
if (ValidateInput(i))
{
output.Post(MyTransform(i));
}
}
There are several options on how to do this:
TransformManyBlockas Jon suggested and return a collection containing 1 or 0 items.TransformBlockwith some special value representing “no value” (e.g.null) and then use aLinkTo()with filter to remove those. You also have to link theTransformBlockto null block (DataflowBlock.NullTarget<T>()) without a filter, to drain the special values.I would consider this something of a hack, but you can also use the
Task-based constructor ofTransformBlock: useTask.FromResult()when you want to return something andnullwhen you don’t. For example: