PipeAndFilter API:IPipeAndFilterAfterAggregate
IPipeAndFilterAfterAggregate<T>
Namespace: PipeFilterCore
Represents the commands after running Aggregate pipe.
public interface IPipeAndFilterAfterAggregate<T> : IPipeAndFilterBuild<T>
Type Parameters
T
Type of contract.
Implements IPipeAndFilterBuild<T>
Methods
AddAggregatePipe(Func<EventPipe<T>, CancellationToken, Task>, String)
Add new aggregate pipe.
IPipeAndFilterAggregate<T> AddAggregatePipe(Func<EventPipe<T>, CancellationToken, Task> command, string alias)
Parameters
command
Func<EventPipe<T>, CancellationToken, Task>
The handler to execute.
The handler command will run after all tasks are executed.
alias
String
The unique alias for pipe.
If the alias is omitted, the alias will be the handler name followed by the reference quantity (if any).
Alias is used to reference in another pipe.
Returns
AddPipe(Func<EventPipe<T>, CancellationToken, Task>, String)
Add new pipe.
IPipeAndFilterPipe<T> AddPipe(Func<EventPipe<T>, CancellationToken, Task> command, string alias)
Parameters
command
Func<EventPipe<T>, CancellationToken, Task>
The handler to execute.
alias
String
The unique alias for pipe.
If the alias is omitted, the alias will be the handler name followed by the reference quantity (if any).
Alias is used to reference in another pipe.
Returns
AddTask(Func<EventPipe<T>, CancellationToken, Task>, String)
Add new task (execution in parallel) through pipe.
IPipeAndFilterAfterAggregate<T> AddTask(Func<EventPipe<T>, CancellationToken, Task> command, string nametask)
Parameters
command
Func<EventPipe<T>, CancellationToken, Task>
The handler to execute.
nametask
String
The name for task (optional).
Returns
IPipeAndFilterAfterAggregate<T>
AddTaskCondition(Func<EventPipe<T>, CancellationToken, Task>, String)
Add new task (execution in parallel) through pipe with conditions.
IPipeAndFilterAfterAggregateCondition<T> AddTaskCondition(Func<EventPipe<T>, CancellationToken, Task> command, string nametask)
Parameters
command
Func<EventPipe<T>, CancellationToken, Task>
The handler to execute.
nametask
String
The name for task (optional).
Returns
IPipeAndFilterAfterAggregateCondition<T>
MaxDegreeProcess(Int32)
Maximum number of concurrent tasks enable.
IPipeAndFilterAfterAggregate<T> MaxDegreeProcess(int value)
Parameters
value
Int32
Number of concurrent tasks.
The default value is number of processors.
Returns
IPipeAndFilterAfterAggregate<T>
WithCondition(Func<EventPipe<T>, CancellationToken, ValueTask<Boolean>>, String)
Add new condition.
IPipeAndFilterAfterAggregate<T> WithCondition(Func<EventPipe<T>, CancellationToken, ValueTask<Boolean>> condition, string namecondition)
Parameters
condition
Func<EventPipe<T>, CancellationToken, ValueTask<Boolean>>
The handle to execute.
namecondition
String
The name for condition(optional).
Returns
IPipeAndFilterAfterAggregate<T>
WithGotoCondition(Func<EventPipe<T>, CancellationToken, ValueTask<Boolean>>, String, String)
Add new go to condition.
If the condition is true, jump to the given pipe without executing the current pipe.
If the false condition continues.
IPipeAndFilterAfterAggregate<T> WithGotoCondition(Func<EventPipe<T>, CancellationToken, ValueTask<Boolean>> condition, string aliasgoto, string namecondition)
Parameters
condition
Func<EventPipe<T>, CancellationToken, ValueTask<Boolean>>
The handle to execute.
aliasgoto
String
The alias to another pipe.
namecondition
String
The name for condition(optional).
Returns
IPipeAndFilterAfterAggregate<T>